stage4/generate_cc/st_code_gen.c
author lbessard
Tue, 19 Jun 2007 08:42:10 +0200
changeset 34 a793b010e371
parent 33 4507beb2aac6
child 35 9f3d6c089533
permissions -rw-r--r--
new generated files
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
     1
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
     2
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
     3
 * IEC 61131-3 standard function lib
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
     4
 * generated code, do not edit by hand
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
     5
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
     6
switch(current_function_type){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
     7
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
     8
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
     9
 *REAL_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    10
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    11
	case function_real_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    12
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    13
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    14
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    15
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    16
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    17
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    18
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    19
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    20
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    21
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    22
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    23
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    24
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    25
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    26
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    27
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    28
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    29
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    30
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    31
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    32
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    33
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    34
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    35
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    36
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    37
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    38
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    39
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    40
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    41
	}/*function_real_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    42
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    43
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    44
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    45
 *REAL_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    46
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    47
	case function_real_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    48
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    49
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    50
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    51
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    52
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    53
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    54
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    55
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    56
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    57
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    58
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    59
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    60
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    61
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    62
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    63
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    64
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    65
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    66
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    67
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    68
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    69
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    70
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    71
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    72
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    73
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    74
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    75
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    76
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    77
	}/*function_real_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    78
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    79
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    80
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    81
 *REAL_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    82
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    83
	case function_real_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    84
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    85
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    86
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    87
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    88
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    89
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    90
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    91
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    92
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    93
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    94
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    95
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    96
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    97
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    98
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
    99
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   100
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   101
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   102
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   103
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   104
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   105
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   106
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   107
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   108
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   109
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   110
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   111
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   112
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   113
	}/*function_real_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   114
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   115
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   116
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   117
 *REAL_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   118
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   119
	case function_real_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   120
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   121
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   122
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   123
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   124
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   125
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   126
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   127
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   128
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   129
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   130
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   131
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   132
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   133
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   134
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   135
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   136
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   137
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   138
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   139
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   140
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   141
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   142
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   143
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   144
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   145
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   146
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   147
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   148
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   149
	}/*function_real_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   150
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   151
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   152
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   153
 *REAL_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   154
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   155
	case function_real_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   156
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   157
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   158
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   159
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   160
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   161
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   162
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   163
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   164
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   165
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   166
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   167
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   168
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   169
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   170
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   171
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   172
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   173
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   174
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   175
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   176
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   177
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   178
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   179
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   180
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   181
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   182
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   183
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   184
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   185
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   186
	}/*function_real_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   187
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   188
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   189
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   190
 *REAL_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   191
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   192
	case function_real_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   193
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   194
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   195
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   196
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   197
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   198
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   199
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   200
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   201
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   202
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   203
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   204
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   205
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   206
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   207
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   208
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   209
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   210
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   211
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   212
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   213
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   214
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   215
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   216
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   217
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   218
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   219
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   220
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   221
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   222
	}/*function_real_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   223
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   224
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   225
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   226
 *REAL_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   227
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   228
	case function_real_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   229
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   230
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   231
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   232
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   233
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   234
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   235
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   236
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   237
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   238
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   239
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   240
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   241
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   242
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   243
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   244
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   245
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   246
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   247
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   248
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   249
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   250
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   251
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   252
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   253
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   254
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   255
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   256
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   257
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   258
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   259
	}/*function_real_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   260
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   261
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   262
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   263
 *REAL_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   264
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   265
	case function_real_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   266
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   267
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   268
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   269
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   270
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   271
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   272
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   273
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   274
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   275
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   276
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   277
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   278
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   279
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   280
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   281
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   282
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   283
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   284
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   285
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   286
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   287
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   288
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   289
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   290
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   291
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   292
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   293
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   294
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   295
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   296
	}/*function_real_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   297
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   298
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   299
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   300
 *REAL_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   301
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   302
	case function_real_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   303
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   304
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   305
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   306
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   307
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   308
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   309
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   310
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   311
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   312
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   313
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   314
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   315
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   316
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   317
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   318
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   319
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   320
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   321
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   322
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   323
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   324
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   325
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   326
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   327
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   328
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   329
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   330
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   331
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   332
	}/*function_real_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   333
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   334
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   335
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   336
 *REAL_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   337
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   338
	case function_real_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   339
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   340
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   341
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   342
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   343
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   344
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   345
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   346
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   347
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   348
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   349
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   350
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   351
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   352
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   353
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   354
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   355
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   356
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   357
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   358
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   359
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   360
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   361
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   362
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   363
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   364
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   365
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   366
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   367
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   368
	}/*function_real_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   369
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   370
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   371
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   372
 *REAL_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   373
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   374
	case function_real_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   375
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   376
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   377
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   378
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   379
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   380
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   381
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   382
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   383
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   384
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   385
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   386
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   387
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   388
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   389
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   390
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   391
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   392
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   393
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   394
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   395
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   396
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   397
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   398
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   399
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   400
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   401
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   402
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   403
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   404
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   405
	}/*function_real_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   406
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   407
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   408
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   409
 *REAL_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   410
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   411
	case function_real_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   412
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   413
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   414
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   415
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   416
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   417
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   418
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   419
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   420
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   421
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   422
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   423
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   424
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   425
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   426
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   427
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   428
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   429
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   430
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   431
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   432
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   433
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   434
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   435
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   436
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   437
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   438
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   439
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   440
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   441
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   442
	}/*function_real_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   443
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   444
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   445
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   446
 *REAL_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   447
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   448
	case function_real_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   449
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   450
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   451
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   452
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   453
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   454
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   455
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   456
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   457
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   458
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   459
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   460
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   461
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   462
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   463
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   464
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   465
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   466
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   467
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   468
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   469
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   470
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   471
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   472
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   473
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   474
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   475
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   476
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   477
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   478
	}/*function_real_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   479
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   480
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   481
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   482
 *REAL_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   483
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   484
	case function_real_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   485
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   486
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   487
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   488
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   489
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   490
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   491
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   492
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   493
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   494
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   495
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   496
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   497
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   498
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   499
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   500
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   501
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   502
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   503
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   504
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   505
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   506
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   507
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   508
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   509
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   510
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   511
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   512
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   513
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   514
	}/*function_real_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   515
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   516
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   517
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   518
 *REAL_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   519
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   520
	case function_real_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   521
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   522
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   523
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   524
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   525
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   526
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   527
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   528
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   529
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   530
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   531
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   532
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   533
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   534
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   535
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   536
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   537
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   538
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   539
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   540
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   541
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   542
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   543
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   544
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   545
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   546
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   547
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   548
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   549
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   550
	}/*function_real_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   551
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   552
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   553
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   554
 *REAL_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   555
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   556
	case function_real_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   557
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   558
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   559
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   560
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   561
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   562
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   563
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   564
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   565
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   566
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   567
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   568
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   569
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   570
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   571
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   572
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   573
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   574
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   575
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   576
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   577
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   578
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   579
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   580
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   581
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   582
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   583
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   584
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   585
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   586
	}/*function_real_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   587
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   588
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   589
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   590
 *REAL_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   591
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   592
	case function_real_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   593
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   594
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   595
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   596
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   597
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   598
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   599
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   600
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   601
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   602
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   603
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   604
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   605
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   606
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   607
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   608
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   609
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   610
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   611
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   612
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   613
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   614
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   615
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   616
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   617
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   618
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   619
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   620
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   621
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   622
	}/*function_real_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   623
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   624
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   625
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   626
 *REAL_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   627
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   628
	case function_real_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   629
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   630
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   631
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   632
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   633
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   634
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   635
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   636
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   637
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   638
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   639
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   640
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   641
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   642
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   643
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   644
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   645
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   646
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   647
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   648
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   649
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   650
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   651
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   652
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   653
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   654
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   655
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   656
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   657
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   658
	}/*function_real_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   659
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   660
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   661
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   662
 *REAL_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   663
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   664
	case function_real_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   665
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   666
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   667
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   668
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   669
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   670
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   671
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   672
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   673
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   674
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   675
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   676
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   677
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   678
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   679
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   680
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   681
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   682
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   683
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   684
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   685
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   686
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   687
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   688
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   689
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   690
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   691
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   692
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   693
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   694
	}/*function_real_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   695
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   696
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   697
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   698
 *REAL_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   699
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   700
	case function_real_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   701
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   702
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   703
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   704
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   705
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   706
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   707
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   708
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   709
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   710
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   711
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   712
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   713
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   714
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   715
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   716
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   717
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   718
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   719
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   720
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   721
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   722
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   723
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   724
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   725
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   726
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   727
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   728
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   729
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   730
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   731
	}/*function_real_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   732
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   733
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   734
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   735
 *REAL_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   736
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   737
	case function_real_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   738
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   739
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   740
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   741
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   742
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   743
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   744
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   745
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   746
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   747
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   748
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   749
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   750
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   751
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   752
			if (typeid(*last_type_symbol) == typeid(real_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   753
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   754
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   755
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   756
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   757
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   758
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   759
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   760
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   761
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   762
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   763
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   764
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   765
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   766
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   767
	}/*function_real_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   768
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   769
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   770
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   771
 *SINT_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   772
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   773
	case function_sint_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   774
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   775
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   776
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   777
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   778
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   779
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   780
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   781
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   782
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   783
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   784
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   785
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   786
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   787
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   788
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   789
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   790
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   791
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   792
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   793
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   794
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   795
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   796
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   797
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   798
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   799
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   800
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   801
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   802
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   803
	}/*function_sint_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   804
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   805
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   806
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   807
 *SINT_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   808
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   809
	case function_sint_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   810
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   811
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   812
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   813
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   814
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   815
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   816
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   817
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   818
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   819
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   820
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   821
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   822
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   823
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   824
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   825
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   826
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   827
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   828
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   829
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   830
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   831
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   832
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   833
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   834
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   835
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   836
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   837
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   838
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   839
	}/*function_sint_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   840
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   841
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   842
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   843
 *SINT_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   844
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   845
	case function_sint_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   846
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   847
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   848
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   849
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   850
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   851
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   852
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   853
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   854
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   855
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   856
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   857
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   858
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   859
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   860
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   861
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   862
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   863
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   864
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   865
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   866
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   867
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   868
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   869
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   870
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   871
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   872
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   873
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   874
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   875
	}/*function_sint_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   876
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   877
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   878
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   879
 *SINT_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   880
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   881
	case function_sint_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   882
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   883
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   884
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   885
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   886
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   887
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   888
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   889
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   890
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   891
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   892
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   893
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   894
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   895
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   896
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   897
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   898
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   899
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   900
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   901
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   902
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   903
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   904
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   905
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   906
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   907
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   908
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   909
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   910
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   911
	}/*function_sint_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   912
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   913
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   914
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   915
 *SINT_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   916
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   917
	case function_sint_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   918
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   919
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   920
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   921
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   922
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   923
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   924
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   925
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   926
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   927
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   928
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   929
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   930
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   931
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   932
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   933
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   934
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   935
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   936
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   937
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   938
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   939
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   940
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   941
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   942
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   943
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   944
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   945
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   946
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   947
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   948
	}/*function_sint_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   949
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   950
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   951
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   952
 *SINT_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   953
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   954
	case function_sint_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   955
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   956
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   957
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   958
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   959
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   960
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   961
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   962
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   963
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   964
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   965
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   966
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   967
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   968
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   969
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   970
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   971
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   972
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   973
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   974
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   975
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   976
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   977
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   978
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   979
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   980
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   981
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   982
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   983
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   984
	}/*function_sint_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   985
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   986
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   987
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   988
 *SINT_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   989
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   990
	case function_sint_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   991
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   992
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   993
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   994
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   995
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   996
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   997
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   998
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
   999
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1000
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1001
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1002
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1003
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1004
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1005
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1006
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1007
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1008
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1009
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1010
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1011
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1012
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1013
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1014
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1015
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1016
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1017
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1018
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1019
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1020
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1021
	}/*function_sint_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1022
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1023
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1024
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1025
 *SINT_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1026
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1027
	case function_sint_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1028
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1029
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1030
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1031
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1032
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1033
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1034
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1035
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1036
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1037
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1038
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1039
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1040
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1041
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1042
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1043
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1044
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1045
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1046
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1047
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1048
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1049
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1050
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1051
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1052
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1053
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1054
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1055
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1056
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1057
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1058
	}/*function_sint_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1059
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1060
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1061
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1062
 *SINT_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1063
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1064
	case function_sint_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1065
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1066
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1067
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1068
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1069
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1070
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1071
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1072
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1073
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1074
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1075
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1076
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1077
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1078
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1079
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1080
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1081
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1082
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1083
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1084
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1085
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1086
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1087
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1088
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1089
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1090
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1091
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1092
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1093
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1094
	}/*function_sint_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1095
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1096
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1097
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1098
 *SINT_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1099
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1100
	case function_sint_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1101
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1102
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1103
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1104
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1105
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1106
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1107
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1108
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1109
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1110
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1111
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1112
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1113
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1114
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1115
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1116
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1117
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1118
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1119
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1120
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1121
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1122
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1123
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1124
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1125
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1126
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1127
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1128
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1129
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1130
	}/*function_sint_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1131
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1132
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1133
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1134
 *SINT_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1135
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1136
	case function_sint_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1137
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1138
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1139
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1140
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1141
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1142
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1143
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1144
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1145
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1146
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1147
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1148
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1149
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1150
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1151
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1152
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1153
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1154
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1155
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1156
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1157
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1158
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1159
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1160
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1161
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1162
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1163
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1164
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1165
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1166
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1167
	}/*function_sint_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1168
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1169
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1170
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1171
 *SINT_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1172
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1173
	case function_sint_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1174
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1175
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1176
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1177
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1178
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1179
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1180
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1181
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1182
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1183
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1184
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1185
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1186
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1187
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1188
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1189
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1190
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1191
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1192
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1193
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1194
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1195
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1196
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1197
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1198
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1199
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1200
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1201
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1202
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1203
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1204
	}/*function_sint_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1205
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1206
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1207
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1208
 *SINT_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1209
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1210
	case function_sint_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1211
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1212
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1213
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1214
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1215
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1216
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1217
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1218
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1219
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1220
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1221
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1222
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1223
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1224
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1225
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1226
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1227
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1228
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1229
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1230
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1231
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1232
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1233
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1234
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1235
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1236
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1237
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1238
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1239
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1240
	}/*function_sint_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1241
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1242
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1243
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1244
 *SINT_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1245
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1246
	case function_sint_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1247
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1248
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1249
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1250
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1251
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1252
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1253
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1254
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1255
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1256
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1257
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1258
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1259
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1260
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1261
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1262
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1263
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1264
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1265
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1266
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1267
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1268
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1269
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1270
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1271
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1272
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1273
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1274
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1275
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1276
	}/*function_sint_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1277
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1278
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1279
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1280
 *SINT_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1281
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1282
	case function_sint_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1283
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1284
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1285
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1286
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1287
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1288
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1289
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1290
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1291
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1292
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1293
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1294
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1295
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1296
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1297
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1298
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1299
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1300
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1301
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1302
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1303
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1304
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1305
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1306
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1307
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1308
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1309
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1310
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1311
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1312
	}/*function_sint_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1313
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1314
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1315
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1316
 *SINT_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1317
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1318
	case function_sint_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1319
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1320
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1321
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1322
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1323
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1324
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1325
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1326
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1327
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1328
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1329
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1330
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1331
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1332
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1333
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1334
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1335
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1336
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1337
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1338
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1339
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1340
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1341
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1342
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1343
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1344
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1345
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1346
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1347
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1348
	}/*function_sint_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1349
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1350
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1351
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1352
 *SINT_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1353
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1354
	case function_sint_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1355
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1356
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1357
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1358
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1359
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1360
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1361
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1362
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1363
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1364
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1365
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1366
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1367
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1368
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1369
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1370
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1371
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1372
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1373
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1374
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1375
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1376
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1377
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1378
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1379
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1380
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1381
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1382
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1383
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1384
	}/*function_sint_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1385
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1386
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1387
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1388
 *SINT_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1389
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1390
	case function_sint_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1391
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1392
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1393
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1394
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1395
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1396
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1397
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1398
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1399
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1400
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1401
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1402
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1403
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1404
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1405
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1406
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1407
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1408
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1409
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1410
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1411
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1412
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1413
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1414
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1415
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1416
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1417
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1418
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1419
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1420
	}/*function_sint_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1421
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1422
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1423
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1424
 *SINT_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1425
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1426
	case function_sint_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1427
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1428
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1429
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1430
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1431
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1432
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1433
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1434
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1435
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1436
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1437
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1438
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1439
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1440
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1441
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1442
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1443
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1444
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1445
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1446
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1447
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1448
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1449
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1450
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1451
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1452
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1453
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1454
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1455
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1456
	}/*function_sint_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1457
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1458
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1459
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1460
 *SINT_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1461
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1462
	case function_sint_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1463
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1464
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1465
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1466
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1467
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1468
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1469
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1470
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1471
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1472
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1473
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1474
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1475
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1476
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1477
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1478
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1479
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1480
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1481
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1482
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1483
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1484
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1485
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1486
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1487
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1488
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1489
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1490
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1491
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1492
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1493
	}/*function_sint_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1494
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1495
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1496
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1497
 *SINT_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1498
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1499
	case function_sint_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1500
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1501
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1502
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1503
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1504
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1505
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1506
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1507
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1508
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1509
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1510
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1511
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1512
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1513
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1514
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1515
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1516
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1517
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1518
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1519
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1520
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1521
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1522
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1523
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1524
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1525
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1526
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1527
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1528
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1529
	}/*function_sint_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1530
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1531
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1532
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1533
 *LINT_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1534
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1535
	case function_lint_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1536
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1537
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1538
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1539
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1540
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1541
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1542
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1543
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1544
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1545
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1546
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1547
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1548
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1549
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1550
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1551
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1552
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1553
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1554
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1555
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1556
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1557
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1558
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1559
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1560
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1561
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1562
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1563
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1564
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1565
	}/*function_lint_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1566
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1567
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1568
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1569
 *LINT_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1570
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1571
	case function_lint_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1572
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1573
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1574
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1575
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1576
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1577
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1578
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1579
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1580
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1581
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1582
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1583
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1584
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1585
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1586
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1587
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1588
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1589
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1590
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1591
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1592
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1593
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1594
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1595
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1596
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1597
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1598
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1599
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1600
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1601
	}/*function_lint_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1602
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1603
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1604
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1605
 *LINT_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1606
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1607
	case function_lint_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1608
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1609
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1610
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1611
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1612
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1613
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1614
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1615
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1616
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1617
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1618
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1619
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1620
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1621
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1622
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1623
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1624
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1625
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1626
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1627
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1628
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1629
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1630
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1631
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1632
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1633
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1634
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1635
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1636
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1637
	}/*function_lint_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1638
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1639
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1640
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1641
 *LINT_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1642
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1643
	case function_lint_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1644
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1645
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1646
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1647
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1648
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1649
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1650
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1651
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1652
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1653
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1654
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1655
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1656
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1657
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1658
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1659
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1660
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1661
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1662
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1663
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1664
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1665
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1666
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1667
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1668
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1669
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1670
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1671
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1672
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1673
	}/*function_lint_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1674
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1675
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1676
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1677
 *LINT_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1678
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1679
	case function_lint_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1680
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1681
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1682
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1683
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1684
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1685
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1686
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1687
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1688
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1689
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1690
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1691
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1692
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1693
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1694
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1695
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1696
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1697
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1698
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1699
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1700
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1701
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1702
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1703
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1704
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1705
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1706
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1707
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1708
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1709
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1710
	}/*function_lint_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1711
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1712
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1713
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1714
 *LINT_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1715
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1716
	case function_lint_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1717
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1718
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1719
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1720
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1721
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1722
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1723
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1724
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1725
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1726
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1727
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1728
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1729
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1730
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1731
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1732
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1733
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1734
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1735
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1736
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1737
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1738
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1739
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1740
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1741
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1742
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1743
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1744
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1745
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1746
	}/*function_lint_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1747
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1748
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1749
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1750
 *LINT_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1751
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1752
	case function_lint_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1753
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1754
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1755
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1756
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1757
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1758
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1759
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1760
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1761
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1762
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1763
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1764
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1765
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1766
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1767
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1768
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1769
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1770
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1771
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1772
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1773
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1774
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1775
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1776
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1777
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1778
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1779
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1780
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1781
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1782
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1783
	}/*function_lint_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1784
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1785
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1786
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1787
 *LINT_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1788
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1789
	case function_lint_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1790
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1791
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1792
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1793
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1794
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1795
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1796
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1797
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1798
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1799
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1800
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1801
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1802
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1803
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1804
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1805
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1806
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1807
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1808
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1809
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1810
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1811
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1812
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1813
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1814
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1815
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1816
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1817
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1818
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1819
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1820
	}/*function_lint_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1821
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1822
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1823
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1824
 *LINT_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1825
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1826
	case function_lint_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1827
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1828
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1829
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1830
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1831
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1832
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1833
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1834
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1835
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1836
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1837
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1838
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1839
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1840
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1841
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1842
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1843
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1844
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1845
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1846
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1847
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1848
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1849
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1850
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1851
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1852
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1853
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1854
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1855
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1856
	}/*function_lint_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1857
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1858
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1859
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1860
 *LINT_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1861
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1862
	case function_lint_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1863
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1864
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1865
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1866
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1867
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1868
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1869
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1870
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1871
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1872
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1873
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1874
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1875
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1876
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1877
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1878
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1879
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1880
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1881
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1882
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1883
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1884
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1885
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1886
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1887
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1888
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1889
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1890
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1891
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1892
	}/*function_lint_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1893
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1894
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1895
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1896
 *LINT_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1897
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1898
	case function_lint_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1899
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1900
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1901
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1902
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1903
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1904
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1905
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1906
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1907
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1908
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1909
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1910
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1911
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1912
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1913
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1914
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1915
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1916
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1917
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1918
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1919
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1920
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1921
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1922
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1923
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1924
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1925
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1926
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1927
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1928
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1929
	}/*function_lint_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1930
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1931
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1932
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1933
 *LINT_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1934
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1935
	case function_lint_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1936
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1937
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1938
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1939
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1940
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1941
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1942
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1943
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1944
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1945
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1946
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1947
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1948
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1949
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1950
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1951
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1952
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1953
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1954
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1955
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1956
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1957
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1958
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1959
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1960
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1961
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1962
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1963
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1964
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1965
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1966
	}/*function_lint_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1967
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1968
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1969
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1970
 *LINT_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1971
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1972
	case function_lint_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1973
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1974
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1975
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1976
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1977
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1978
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1979
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1980
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1981
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1982
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1983
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1984
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1985
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1986
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1987
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1988
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1989
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1990
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1991
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1992
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1993
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1994
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1995
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1996
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1997
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1998
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  1999
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2000
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2001
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2002
	}/*function_lint_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2003
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2004
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2005
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2006
 *LINT_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2007
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2008
	case function_lint_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2009
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2010
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2011
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2012
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2013
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2014
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2015
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2016
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2017
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2018
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2019
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2020
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2021
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2022
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2023
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2024
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2025
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2026
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2027
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2028
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2029
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2030
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2031
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2032
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2033
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2034
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2035
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2036
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2037
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2038
	}/*function_lint_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2039
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2040
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2041
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2042
 *LINT_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2043
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2044
	case function_lint_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2045
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2046
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2047
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2048
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2049
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2050
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2051
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2052
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2053
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2054
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2055
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2056
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2057
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2058
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2059
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2060
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2061
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2062
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2063
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2064
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2065
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2066
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2067
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2068
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2069
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2070
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2071
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2072
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2073
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2074
	}/*function_lint_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2075
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2076
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2077
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2078
 *LINT_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2079
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2080
	case function_lint_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2081
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2082
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2083
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2084
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2085
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2086
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2087
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2088
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2089
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2090
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2091
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2092
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2093
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2094
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2095
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2096
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2097
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2098
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2099
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2100
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2101
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2102
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2103
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2104
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2105
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2106
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2107
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2108
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2109
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2110
	}/*function_lint_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2111
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2112
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2113
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2114
 *LINT_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2115
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2116
	case function_lint_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2117
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2118
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2119
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2120
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2121
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2122
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2123
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2124
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2125
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2126
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2127
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2128
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2129
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2130
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2131
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2132
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2133
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2134
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2135
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2136
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2137
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2138
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2139
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2140
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2141
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2142
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2143
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2144
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2145
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2146
	}/*function_lint_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2147
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2148
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2149
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2150
 *LINT_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2151
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2152
	case function_lint_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2153
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2154
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2155
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2156
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2157
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2158
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2159
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2160
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2161
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2162
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2163
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2164
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2165
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2166
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2167
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2168
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2169
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2170
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2171
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2172
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2173
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2174
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2175
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2176
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2177
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2178
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2179
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2180
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2181
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2182
	}/*function_lint_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2183
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2184
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2185
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2186
 *LINT_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2187
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2188
	case function_lint_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2189
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2190
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2191
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2192
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2193
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2194
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2195
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2196
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2197
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2198
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2199
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2200
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2201
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2202
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2203
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2204
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2205
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2206
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2207
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2208
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2209
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2210
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2211
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2212
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2213
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2214
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2215
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2216
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2217
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2218
	}/*function_lint_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2219
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2220
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2221
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2222
 *LINT_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2223
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2224
	case function_lint_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2225
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2226
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2227
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2228
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2229
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2230
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2231
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2232
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2233
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2234
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2235
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2236
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2237
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2238
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2239
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2240
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2241
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2242
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2243
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2244
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2245
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2246
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2247
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2248
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2249
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2250
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2251
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2252
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2253
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2254
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2255
	}/*function_lint_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2256
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2257
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2258
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2259
 *LINT_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2260
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2261
	case function_lint_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2262
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2263
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2264
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2265
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2266
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2267
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2268
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2269
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2270
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2271
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2272
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2273
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2274
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2275
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2276
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2277
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2278
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2279
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2280
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2281
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2282
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2283
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2284
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2285
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2286
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2287
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2288
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2289
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2290
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2291
	}/*function_lint_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2292
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2293
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2294
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2295
 *DINT_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2296
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2297
	case function_dint_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2298
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2299
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2300
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2301
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2302
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2303
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2304
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2305
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2306
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2307
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2308
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2309
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2310
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2311
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2312
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2313
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2314
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2315
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2316
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2317
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2318
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2319
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2320
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2321
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2322
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2323
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2324
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2325
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2326
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2327
	}/*function_dint_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2328
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2329
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2330
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2331
 *DINT_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2332
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2333
	case function_dint_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2334
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2335
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2336
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2337
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2338
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2339
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2340
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2341
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2342
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2343
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2344
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2345
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2346
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2347
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2348
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2349
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2350
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2351
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2352
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2353
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2354
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2355
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2356
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2357
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2358
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2359
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2360
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2361
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2362
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2363
	}/*function_dint_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2364
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2365
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2366
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2367
 *DINT_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2368
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2369
	case function_dint_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2370
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2371
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2372
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2373
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2374
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2375
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2376
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2377
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2378
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2379
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2380
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2381
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2382
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2383
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2384
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2385
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2386
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2387
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2388
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2389
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2390
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2391
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2392
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2393
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2394
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2395
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2396
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2397
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2398
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2399
	}/*function_dint_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2400
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2401
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2402
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2403
 *DINT_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2404
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2405
	case function_dint_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2406
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2407
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2408
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2409
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2410
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2411
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2412
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2413
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2414
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2415
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2416
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2417
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2418
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2419
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2420
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2421
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2422
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2423
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2424
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2425
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2426
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2427
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2428
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2429
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2430
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2431
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2432
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2433
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2434
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2435
	}/*function_dint_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2436
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2437
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2438
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2439
 *DINT_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2440
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2441
	case function_dint_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2442
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2443
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2444
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2445
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2446
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2447
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2448
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2449
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2450
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2451
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2452
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2453
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2454
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2455
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2456
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2457
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2458
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2459
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2460
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2461
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2462
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2463
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2464
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2465
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2466
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2467
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2468
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2469
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2470
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2471
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2472
	}/*function_dint_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2473
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2474
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2475
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2476
 *DINT_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2477
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2478
	case function_dint_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2479
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2480
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2481
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2482
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2483
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2484
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2485
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2486
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2487
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2488
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2489
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2490
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2491
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2492
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2493
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2494
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2495
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2496
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2497
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2498
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2499
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2500
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2501
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2502
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2503
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2504
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2505
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2506
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2507
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2508
	}/*function_dint_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2509
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2510
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2511
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2512
 *DINT_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2513
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2514
	case function_dint_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2515
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2516
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2517
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2518
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2519
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2520
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2521
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2522
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2523
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2524
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2525
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2526
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2527
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2528
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2529
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2530
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2531
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2532
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2533
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2534
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2535
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2536
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2537
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2538
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2539
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2540
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2541
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2542
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2543
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2544
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2545
	}/*function_dint_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2546
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2547
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2548
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2549
 *DINT_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2550
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2551
	case function_dint_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2552
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2553
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2554
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2555
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2556
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2557
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2558
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2559
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2560
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2561
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2562
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2563
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2564
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2565
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2566
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2567
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2568
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2569
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2570
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2571
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2572
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2573
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2574
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2575
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2576
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2577
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2578
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2579
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2580
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2581
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2582
	}/*function_dint_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2583
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2584
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2585
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2586
 *DINT_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2587
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2588
	case function_dint_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2589
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2590
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2591
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2592
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2593
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2594
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2595
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2596
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2597
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2598
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2599
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2600
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2601
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2602
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2603
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2604
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2605
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2606
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2607
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2608
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2609
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2610
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2611
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2612
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2613
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2614
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2615
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2616
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2617
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2618
	}/*function_dint_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2619
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2620
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2621
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2622
 *DINT_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2623
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2624
	case function_dint_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2625
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2626
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2627
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2628
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2629
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2630
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2631
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2632
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2633
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2634
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2635
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2636
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2637
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2638
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2639
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2640
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2641
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2642
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2643
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2644
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2645
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2646
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2647
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2648
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2649
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2650
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2651
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2652
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2653
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2654
	}/*function_dint_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2655
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2656
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2657
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2658
 *DINT_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2659
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2660
	case function_dint_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2661
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2662
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2663
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2664
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2665
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2666
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2667
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2668
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2669
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2670
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2671
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2672
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2673
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2674
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2675
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2676
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2677
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2678
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2679
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2680
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2681
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2682
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2683
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2684
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2685
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2686
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2687
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2688
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2689
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2690
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2691
	}/*function_dint_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2692
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2693
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2694
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2695
 *DINT_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2696
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2697
	case function_dint_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2698
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2699
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2700
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2701
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2702
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2703
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2704
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2705
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2706
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2707
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2708
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2709
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2710
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2711
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2712
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2713
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2714
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2715
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2716
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2717
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2718
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2719
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2720
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2721
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2722
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2723
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2724
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2725
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2726
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2727
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2728
	}/*function_dint_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2729
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2730
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2731
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2732
 *DINT_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2733
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2734
	case function_dint_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2735
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2736
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2737
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2738
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2739
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2740
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2741
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2742
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2743
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2744
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2745
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2746
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2747
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2748
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2749
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2750
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2751
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2752
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2753
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2754
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2755
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2756
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2757
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2758
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2759
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2760
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2761
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2762
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2763
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2764
	}/*function_dint_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2765
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2766
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2767
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2768
 *DINT_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2769
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2770
	case function_dint_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2771
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2772
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2773
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2774
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2775
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2776
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2777
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2778
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2779
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2780
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2781
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2782
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2783
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2784
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2785
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2786
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2787
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2788
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2789
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2790
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2791
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2792
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2793
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2794
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2795
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2796
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2797
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2798
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2799
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2800
	}/*function_dint_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2801
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2802
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2803
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2804
 *DINT_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2805
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2806
	case function_dint_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2807
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2808
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2809
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2810
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2811
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2812
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2813
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2814
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2815
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2816
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2817
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2818
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2819
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2820
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2821
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2822
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2823
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2824
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2825
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2826
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2827
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2828
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2829
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2830
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2831
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2832
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2833
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2834
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2835
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2836
	}/*function_dint_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2837
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2838
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2839
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2840
 *DINT_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2841
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2842
	case function_dint_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2843
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2844
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2845
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2846
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2847
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2848
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2849
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2850
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2851
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2852
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2853
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2854
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2855
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2856
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2857
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2858
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2859
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2860
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2861
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2862
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2863
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2864
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2865
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2866
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2867
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2868
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2869
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2870
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2871
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2872
	}/*function_dint_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2873
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2874
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2875
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2876
 *DINT_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2877
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2878
	case function_dint_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2879
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2880
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2881
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2882
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2883
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2884
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2885
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2886
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2887
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2888
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2889
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2890
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2891
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2892
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2893
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2894
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2895
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2896
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2897
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2898
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2899
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2900
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2901
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2902
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2903
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2904
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2905
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2906
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2907
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2908
	}/*function_dint_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2909
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2910
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2911
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2912
 *DINT_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2913
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2914
	case function_dint_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2915
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2916
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2917
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2918
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2919
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2920
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2921
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2922
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2923
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2924
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2925
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2926
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2927
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2928
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2929
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2930
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2931
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2932
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2933
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2934
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2935
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2936
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2937
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2938
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2939
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2940
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2941
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2942
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2943
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2944
	}/*function_dint_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2945
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2946
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2947
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2948
 *DINT_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2949
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2950
	case function_dint_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2951
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2952
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2953
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2954
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2955
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2956
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2957
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2958
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2959
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2960
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2961
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2962
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2963
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2964
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2965
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2966
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2967
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2968
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2969
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2970
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2971
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2972
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2973
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2974
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2975
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2976
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2977
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2978
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2979
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2980
	}/*function_dint_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2981
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2982
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2983
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2984
 *DINT_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2985
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2986
	case function_dint_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2987
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2988
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2989
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2990
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2991
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2992
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2993
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2994
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2995
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2996
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2997
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2998
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  2999
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3000
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3001
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3002
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3003
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3004
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3005
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3006
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3007
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3008
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3009
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3010
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3011
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3012
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3013
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3014
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3015
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3016
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3017
	}/*function_dint_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3018
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3019
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3020
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3021
 *DINT_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3022
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3023
	case function_dint_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3024
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3025
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3026
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3027
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3028
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3029
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3030
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3031
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3032
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3033
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3034
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3035
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3036
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3037
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3038
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3039
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3040
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3041
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3042
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3043
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3044
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3045
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3046
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3047
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3048
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3049
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3050
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3051
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3052
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3053
	}/*function_dint_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3054
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3055
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3056
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3057
 *DATE_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3058
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3059
	case function_date_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3060
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3061
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3062
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3063
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3064
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3065
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3066
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3067
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3068
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3069
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3070
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3071
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3072
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3073
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3074
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3075
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3076
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3077
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3078
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3079
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3080
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3081
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3082
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3083
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3084
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3085
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3086
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3087
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3088
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3089
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3090
	}/*function_date_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3091
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3092
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3093
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3094
 *DATE_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3095
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3096
	case function_date_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3097
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3098
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3099
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3100
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3101
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3102
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3103
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3104
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3105
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3106
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3107
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3108
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3109
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3110
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3111
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3112
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3113
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3114
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3115
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3116
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3117
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3118
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3119
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3120
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3121
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3122
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3123
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3124
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3125
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3126
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3127
	}/*function_date_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3128
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3129
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3130
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3131
 *DATE_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3132
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3133
	case function_date_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3134
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3135
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3136
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3137
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3138
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3139
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3140
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3141
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3142
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3143
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3144
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3145
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3146
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3147
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3148
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3149
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3150
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3151
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3152
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3153
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3154
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3155
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3156
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3157
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3158
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3159
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3160
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3161
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3162
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3163
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3164
	}/*function_date_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3165
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3166
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3167
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3168
 *DATE_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3169
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3170
	case function_date_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3171
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3172
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3173
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3174
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3175
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3176
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3177
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3178
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3179
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3180
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3181
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3182
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3183
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3184
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3185
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3186
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3187
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3188
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3189
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3190
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3191
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3192
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3193
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3194
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3195
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3196
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3197
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3198
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3199
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3200
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3201
	}/*function_date_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3202
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3203
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3204
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3205
 *DATE_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3206
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3207
	case function_date_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3208
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3209
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3210
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3211
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3212
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3213
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3214
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3215
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3216
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3217
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3218
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3219
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3220
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3221
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3222
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3223
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3224
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3225
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3226
				s4o.print("#error DATE_TO_DATE not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3227
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3228
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3229
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3230
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3231
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3232
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3233
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3234
	}/*function_date_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3235
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3236
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3237
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3238
 *DATE_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3239
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3240
	case function_date_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3241
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3242
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3243
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3244
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3245
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3246
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3247
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3248
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3249
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3250
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3251
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3252
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3253
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3254
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3255
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3256
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3257
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3258
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3259
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3260
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3261
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3262
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3263
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3264
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3265
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3266
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3267
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3268
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3269
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3270
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3271
	}/*function_date_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3272
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3273
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3274
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3275
 *DATE_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3276
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3277
	case function_date_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3278
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3279
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3280
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3281
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3282
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3283
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3284
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3285
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3286
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3287
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3288
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3289
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3290
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3291
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3292
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3293
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3294
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3295
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3296
				s4o.print("#error DATE_TO_DT not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3297
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3298
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3299
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3300
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3301
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3302
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3303
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3304
	}/*function_date_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3305
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3306
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3307
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3308
 *DATE_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3309
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3310
	case function_date_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3311
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3312
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3313
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3314
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3315
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3316
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3317
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3318
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3319
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3320
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3321
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3322
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3323
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3324
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3325
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3326
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3327
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3328
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3329
				s4o.print("#error DATE_TO_TOD not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3330
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3331
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3332
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3333
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3334
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3335
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3336
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3337
	}/*function_date_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3338
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3339
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3340
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3341
 *DATE_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3342
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3343
	case function_date_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3344
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3345
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3346
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3347
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3348
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3349
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3350
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3351
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3352
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3353
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3354
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3355
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3356
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3357
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3358
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3359
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3360
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3361
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3362
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3363
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3364
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3365
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3366
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3367
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3368
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3369
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3370
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3371
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3372
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3373
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3374
	}/*function_date_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3375
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3376
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3377
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3378
 *DATE_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3379
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3380
	case function_date_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3381
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3382
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3383
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3384
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3385
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3386
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3387
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3388
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3389
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3390
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3391
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3392
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3393
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3394
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3395
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3396
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3397
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3398
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3399
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3400
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3401
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3402
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3403
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3404
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3405
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3406
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3407
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3408
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3409
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3410
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3411
	}/*function_date_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3412
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3413
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3414
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3415
 *DATE_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3416
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3417
	case function_date_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3418
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3419
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3420
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3421
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3422
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3423
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3424
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3425
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3426
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3427
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3428
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3429
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3430
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3431
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3432
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3433
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3434
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3435
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3436
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3437
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3438
				s4o.print(")string_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3439
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3440
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3441
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3442
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3443
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3444
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3445
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3446
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3447
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3448
	}/*function_date_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3449
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3450
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3451
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3452
 *DATE_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3453
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3454
	case function_date_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3455
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3456
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3457
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3458
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3459
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3460
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3461
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3462
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3463
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3464
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3465
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3466
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3467
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3468
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3469
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3470
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3471
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3472
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3473
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3474
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3475
				s4o.print(")string_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3476
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3477
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3478
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3479
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3480
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3481
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3482
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3483
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3484
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3485
	}/*function_date_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3486
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3487
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3488
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3489
 *DATE_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3490
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3491
	case function_date_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3492
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3493
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3494
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3495
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3496
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3497
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3498
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3499
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3500
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3501
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3502
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3503
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3504
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3505
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3506
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3507
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3508
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3509
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3510
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3511
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3512
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3513
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3514
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3515
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3516
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3517
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3518
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3519
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3520
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3521
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3522
	}/*function_date_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3523
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3524
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3525
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3526
 *DATE_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3527
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3528
	case function_date_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3529
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3530
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3531
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3532
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3533
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3534
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3535
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3536
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3537
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3538
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3539
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3540
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3541
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3542
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3543
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3544
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3545
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3546
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3547
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3548
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3549
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3550
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3551
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3552
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3553
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3554
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3555
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3556
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3557
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3558
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3559
	}/*function_date_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3560
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3561
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3562
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3563
 *DATE_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3564
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3565
	case function_date_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3566
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3567
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3568
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3569
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3570
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3571
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3572
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3573
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3574
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3575
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3576
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3577
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3578
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3579
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3580
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3581
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3582
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3583
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3584
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3585
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3586
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3587
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3588
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3589
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3590
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3591
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3592
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3593
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3594
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3595
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3596
	}/*function_date_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3597
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3598
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3599
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3600
 *DATE_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3601
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3602
	case function_date_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3603
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3604
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3605
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3606
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3607
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3608
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3609
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3610
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3611
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3612
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3613
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3614
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3615
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3616
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3617
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3618
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3619
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3620
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3621
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3622
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3623
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3624
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3625
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3626
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3627
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3628
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3629
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3630
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3631
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3632
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3633
	}/*function_date_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3634
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3635
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3636
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3637
 *DATE_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3638
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3639
	case function_date_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3640
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3641
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3642
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3643
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3644
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3645
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3646
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3647
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3648
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3649
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3650
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3651
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3652
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3653
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3654
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3655
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3656
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3657
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3658
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3659
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3660
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3661
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3662
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3663
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3664
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3665
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3666
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3667
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3668
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3669
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3670
	}/*function_date_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3671
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3672
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3673
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3674
 *DATE_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3675
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3676
	case function_date_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3677
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3678
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3679
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3680
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3681
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3682
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3683
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3684
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3685
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3686
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3687
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3688
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3689
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3690
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3691
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3692
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3693
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3694
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3695
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3696
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3697
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3698
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3699
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3700
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3701
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3702
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3703
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3704
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3705
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3706
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3707
	}/*function_date_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3708
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3709
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3710
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3711
 *DATE_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3712
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3713
	case function_date_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3714
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3715
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3716
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3717
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3718
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3719
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3720
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3721
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3722
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3723
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3724
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3725
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3726
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3727
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3728
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3729
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3730
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3731
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3732
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3733
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3734
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3735
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3736
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3737
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3738
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3739
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3740
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3741
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3742
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3743
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3744
	}/*function_date_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3745
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3746
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3747
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3748
 *DATE_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3749
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3750
	case function_date_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3751
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3752
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3753
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3754
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3755
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3756
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3757
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3758
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3759
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3760
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3761
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3762
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3763
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3764
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3765
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3766
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3767
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3768
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3769
				s4o.print("#error DATE_TO_TIME not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3770
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3771
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3772
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3773
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3774
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3775
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3776
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3777
	}/*function_date_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3778
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3779
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3780
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3781
 *DATE_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3782
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3783
	case function_date_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3784
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3785
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3786
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3787
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3788
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3789
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3790
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3791
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3792
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3793
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3794
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3795
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3796
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3797
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3798
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3799
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3800
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3801
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3802
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3803
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3804
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3805
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3806
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3807
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3808
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3809
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3810
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3811
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3812
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3813
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3814
	}/*function_date_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3815
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3816
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3817
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3818
 *DWORD_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3819
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3820
	case function_dword_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3821
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3822
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3823
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3824
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3825
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3826
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3827
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3828
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3829
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3830
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3831
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3832
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3833
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3834
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3835
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3836
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3837
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3838
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3839
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3840
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3841
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3842
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3843
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3844
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3845
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3846
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3847
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3848
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3849
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3850
	}/*function_dword_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3851
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3852
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3853
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3854
 *DWORD_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3855
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3856
	case function_dword_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3857
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3858
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3859
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3860
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3861
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3862
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3863
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3864
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3865
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3866
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3867
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3868
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3869
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3870
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3871
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3872
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3873
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3874
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3875
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3876
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3877
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3878
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3879
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3880
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3881
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3882
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3883
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3884
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3885
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3886
	}/*function_dword_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3887
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3888
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3889
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3890
 *DWORD_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3891
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3892
	case function_dword_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3893
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3894
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3895
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3896
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3897
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3898
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3899
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3900
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3901
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3902
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3903
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3904
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3905
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3906
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3907
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3908
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3909
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3910
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3911
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3912
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3913
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3914
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3915
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3916
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3917
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3918
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3919
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3920
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3921
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3922
	}/*function_dword_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3923
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3924
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3925
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3926
 *DWORD_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3927
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3928
	case function_dword_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3929
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3930
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3931
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3932
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3933
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3934
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3935
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3936
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3937
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3938
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3939
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3940
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3941
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3942
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3943
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3944
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3945
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3946
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3947
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3948
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3949
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3950
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3951
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3952
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3953
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3954
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3955
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3956
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3957
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3958
	}/*function_dword_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3959
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3960
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3961
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3962
 *DWORD_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3963
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3964
	case function_dword_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3965
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3966
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3967
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3968
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3969
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3970
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3971
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3972
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3973
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3974
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3975
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3976
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3977
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3978
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3979
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3980
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3981
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3982
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3983
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3984
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3985
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3986
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3987
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3988
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3989
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3990
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3991
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3992
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3993
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3994
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3995
	}/*function_dword_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3996
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3997
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3998
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  3999
 *DWORD_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4000
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4001
	case function_dword_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4002
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4003
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4004
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4005
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4006
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4007
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4008
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4009
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4010
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4011
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4012
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4013
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4014
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4015
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4016
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4017
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4018
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4019
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4020
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4021
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4022
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4023
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4024
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4025
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4026
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4027
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4028
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4029
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4030
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4031
	}/*function_dword_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4032
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4033
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4034
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4035
 *DWORD_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4036
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4037
	case function_dword_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4038
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4039
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4040
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4041
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4042
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4043
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4044
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4045
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4046
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4047
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4048
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4049
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4050
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4051
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4052
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4053
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4054
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4055
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4056
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4057
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4058
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4059
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4060
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4061
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4062
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4063
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4064
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4065
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4066
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4067
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4068
	}/*function_dword_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4069
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4070
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4071
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4072
 *DWORD_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4073
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4074
	case function_dword_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4075
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4076
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4077
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4078
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4079
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4080
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4081
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4082
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4083
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4084
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4085
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4086
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4087
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4088
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4089
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4090
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4091
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4092
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4093
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4094
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4095
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4096
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4097
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4098
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4099
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4100
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4101
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4102
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4103
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4104
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4105
	}/*function_dword_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4106
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4107
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4108
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4109
 *DWORD_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4110
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4111
	case function_dword_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4112
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4113
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4114
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4115
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4116
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4117
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4118
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4119
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4120
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4121
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4122
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4123
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4124
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4125
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4126
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4127
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4128
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4129
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4130
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4131
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4132
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4133
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4134
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4135
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4136
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4137
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4138
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4139
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4140
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4141
	}/*function_dword_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4142
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4143
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4144
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4145
 *DWORD_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4146
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4147
	case function_dword_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4148
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4149
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4150
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4151
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4152
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4153
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4154
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4155
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4156
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4157
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4158
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4159
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4160
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4161
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4162
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4163
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4164
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4165
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4166
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4167
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4168
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4169
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4170
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4171
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4172
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4173
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4174
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4175
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4176
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4177
	}/*function_dword_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4178
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4179
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4180
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4181
 *DWORD_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4182
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4183
	case function_dword_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4184
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4185
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4186
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4187
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4188
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4189
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4190
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4191
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4192
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4193
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4194
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4195
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4196
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4197
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4198
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4199
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4200
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4201
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4202
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4203
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4204
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4205
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4206
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4207
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4208
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4209
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4210
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4211
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4212
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4213
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4214
	}/*function_dword_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4215
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4216
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4217
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4218
 *DWORD_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4219
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4220
	case function_dword_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4221
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4222
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4223
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4224
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4225
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4226
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4227
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4228
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4229
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4230
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4231
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4232
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4233
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4234
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4235
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4236
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4237
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4238
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4239
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4240
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4241
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4242
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4243
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4244
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4245
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4246
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4247
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4248
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4249
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4250
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4251
	}/*function_dword_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4252
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4253
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4254
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4255
 *DWORD_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4256
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4257
	case function_dword_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4258
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4259
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4260
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4261
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4262
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4263
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4264
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4265
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4266
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4267
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4268
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4269
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4270
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4271
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4272
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4273
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4274
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4275
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4276
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4277
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4278
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4279
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4280
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4281
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4282
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4283
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4284
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4285
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4286
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4287
	}/*function_dword_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4288
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4289
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4290
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4291
 *DWORD_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4292
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4293
	case function_dword_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4294
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4295
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4296
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4297
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4298
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4299
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4300
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4301
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4302
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4303
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4304
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4305
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4306
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4307
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4308
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4309
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4310
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4311
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4312
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4313
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4314
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4315
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4316
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4317
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4318
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4319
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4320
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4321
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4322
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4323
	}/*function_dword_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4324
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4325
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4326
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4327
 *DWORD_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4328
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4329
	case function_dword_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4330
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4331
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4332
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4333
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4334
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4335
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4336
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4337
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4338
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4339
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4340
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4341
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4342
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4343
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4344
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4345
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4346
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4347
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4348
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4349
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4350
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4351
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4352
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4353
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4354
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4355
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4356
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4357
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4358
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4359
	}/*function_dword_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4360
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4361
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4362
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4363
 *DWORD_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4364
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4365
	case function_dword_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4366
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4367
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4368
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4369
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4370
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4371
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4372
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4373
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4374
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4375
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4376
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4377
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4378
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4379
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4380
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4381
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4382
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4383
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4384
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4385
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4386
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4387
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4388
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4389
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4390
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4391
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4392
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4393
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4394
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4395
	}/*function_dword_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4396
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4397
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4398
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4399
 *DWORD_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4400
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4401
	case function_dword_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4402
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4403
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4404
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4405
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4406
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4407
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4408
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4409
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4410
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4411
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4412
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4413
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4414
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4415
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4416
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4417
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4418
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4419
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4420
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4421
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4422
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4423
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4424
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4425
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4426
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4427
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4428
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4429
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4430
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4431
	}/*function_dword_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4432
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4433
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4434
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4435
 *DWORD_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4436
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4437
	case function_dword_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4438
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4439
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4440
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4441
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4442
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4443
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4444
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4445
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4446
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4447
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4448
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4449
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4450
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4451
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4452
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4453
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4454
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4455
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4456
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4457
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4458
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4459
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4460
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4461
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4462
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4463
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4464
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4465
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4466
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4467
	}/*function_dword_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4468
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4469
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4470
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4471
 *DWORD_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4472
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4473
	case function_dword_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4474
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4475
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4476
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4477
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4478
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4479
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4480
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4481
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4482
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4483
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4484
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4485
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4486
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4487
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4488
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4489
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4490
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4491
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4492
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4493
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4494
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4495
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4496
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4497
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4498
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4499
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4500
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4501
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4502
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4503
	}/*function_dword_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4504
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4505
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4506
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4507
 *DWORD_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4508
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4509
	case function_dword_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4510
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4511
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4512
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4513
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4514
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4515
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4516
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4517
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4518
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4519
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4520
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4521
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4522
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4523
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4524
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4525
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4526
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4527
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4528
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4529
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4530
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4531
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4532
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4533
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4534
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4535
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4536
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4537
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4538
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4539
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4540
	}/*function_dword_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4541
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4542
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4543
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4544
 *DWORD_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4545
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4546
	case function_dword_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4547
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4548
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4549
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4550
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4551
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4552
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4553
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4554
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4555
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4556
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4557
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4558
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4559
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4560
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4561
			if (typeid(*last_type_symbol) == typeid(dword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4562
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4563
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4564
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4565
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4566
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4567
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4568
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4569
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4570
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4571
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4572
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4573
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4574
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4575
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4576
	}/*function_dword_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4577
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4578
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4579
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4580
 *DT_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4581
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4582
	case function_dt_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4583
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4584
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4585
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4586
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4587
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4588
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4589
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4590
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4591
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4592
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4593
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4594
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4595
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4596
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4597
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4598
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4599
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4600
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4601
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4602
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4603
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4604
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4605
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4606
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4607
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4608
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4609
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4610
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4611
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4612
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4613
	}/*function_dt_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4614
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4615
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4616
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4617
 *DT_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4618
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4619
	case function_dt_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4620
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4621
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4622
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4623
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4624
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4625
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4626
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4627
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4628
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4629
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4630
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4631
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4632
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4633
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4634
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4635
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4636
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4637
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4638
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4639
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4640
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4641
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4642
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4643
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4644
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4645
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4646
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4647
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4648
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4649
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4650
	}/*function_dt_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4651
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4652
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4653
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4654
 *DT_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4655
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4656
	case function_dt_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4657
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4658
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4659
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4660
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4661
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4662
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4663
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4664
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4665
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4666
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4667
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4668
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4669
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4670
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4671
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4672
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4673
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4674
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4675
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4676
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4677
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4678
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4679
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4680
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4681
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4682
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4683
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4684
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4685
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4686
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4687
	}/*function_dt_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4688
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4689
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4690
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4691
 *DT_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4692
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4693
	case function_dt_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4694
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4695
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4696
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4697
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4698
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4699
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4700
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4701
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4702
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4703
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4704
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4705
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4706
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4707
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4708
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4709
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4710
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4711
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4712
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4713
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4714
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4715
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4716
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4717
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4718
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4719
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4720
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4721
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4722
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4723
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4724
	}/*function_dt_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4725
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4726
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4727
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4728
 *DT_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4729
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4730
	case function_dt_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4731
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4732
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4733
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4734
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4735
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4736
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4737
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4738
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4739
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4740
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4741
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4742
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4743
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4744
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4745
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4746
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4747
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4748
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4749
				s4o.print("#error DT_TO_DATE not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4750
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4751
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4752
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4753
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4754
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4755
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4756
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4757
	}/*function_dt_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4758
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4759
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4760
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4761
 *DT_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4762
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4763
	case function_dt_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4764
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4765
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4766
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4767
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4768
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4769
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4770
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4771
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4772
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4773
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4774
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4775
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4776
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4777
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4778
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4779
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4780
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4781
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4782
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4783
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4784
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4785
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4786
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4787
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4788
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4789
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4790
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4791
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4792
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4793
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4794
	}/*function_dt_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4795
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4796
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4797
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4798
 *DT_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4799
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4800
	case function_dt_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4801
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4802
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4803
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4804
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4805
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4806
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4807
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4808
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4809
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4810
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4811
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4812
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4813
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4814
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4815
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4816
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4817
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4818
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4819
				s4o.print("#error DT_TO_DT not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4820
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4821
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4822
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4823
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4824
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4825
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4826
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4827
	}/*function_dt_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4828
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4829
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4830
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4831
 *DT_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4832
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4833
	case function_dt_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4834
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4835
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4836
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4837
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4838
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4839
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4840
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4841
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4842
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4843
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4844
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4845
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4846
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4847
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4848
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4849
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4850
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4851
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4852
				s4o.print("#error DT_TO_TOD not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4853
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4854
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4855
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4856
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4857
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4858
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4859
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4860
	}/*function_dt_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4861
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4862
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4863
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4864
 *DT_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4865
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4866
	case function_dt_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4867
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4868
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4869
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4870
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4871
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4872
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4873
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4874
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4875
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4876
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4877
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4878
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4879
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4880
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4881
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4882
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4883
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4884
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4885
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4886
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4887
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4888
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4889
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4890
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4891
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4892
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4893
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4894
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4895
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4896
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4897
	}/*function_dt_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4898
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4899
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4900
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4901
 *DT_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4902
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4903
	case function_dt_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4904
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4905
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4906
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4907
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4908
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4909
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4910
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4911
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4912
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4913
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4914
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4915
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4916
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4917
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4918
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4919
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4920
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4921
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4922
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4923
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4924
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4925
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4926
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4927
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4928
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4929
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4930
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4931
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4932
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4933
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4934
	}/*function_dt_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4935
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4936
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4937
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4938
 *DT_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4939
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4940
	case function_dt_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4941
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4942
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4943
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4944
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4945
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4946
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4947
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4948
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4949
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4950
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4951
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4952
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4953
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4954
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4955
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4956
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4957
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4958
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4959
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4960
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4961
				s4o.print(")string_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4962
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4963
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4964
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4965
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4966
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4967
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4968
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4969
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4970
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4971
	}/*function_dt_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4972
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4973
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4974
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4975
 *DT_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4976
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4977
	case function_dt_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4978
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4979
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4980
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4981
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4982
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4983
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4984
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4985
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4986
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4987
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4988
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4989
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4990
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4991
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4992
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4993
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4994
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4995
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4996
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4997
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4998
				s4o.print(")string_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  4999
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5000
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5001
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5002
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5003
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5004
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5005
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5006
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5007
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5008
	}/*function_dt_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5009
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5010
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5011
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5012
 *DT_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5013
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5014
	case function_dt_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5015
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5016
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5017
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5018
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5019
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5020
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5021
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5022
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5023
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5024
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5025
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5026
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5027
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5028
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5029
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5030
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5031
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5032
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5033
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5034
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5035
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5036
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5037
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5038
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5039
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5040
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5041
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5042
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5043
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5044
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5045
	}/*function_dt_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5046
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5047
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5048
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5049
 *DT_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5050
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5051
	case function_dt_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5052
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5053
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5054
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5055
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5056
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5057
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5058
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5059
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5060
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5061
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5062
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5063
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5064
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5065
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5066
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5067
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5068
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5069
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5070
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5071
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5072
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5073
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5074
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5075
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5076
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5077
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5078
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5079
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5080
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5081
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5082
	}/*function_dt_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5083
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5084
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5085
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5086
 *DT_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5087
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5088
	case function_dt_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5089
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5090
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5091
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5092
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5093
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5094
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5095
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5096
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5097
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5098
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5099
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5100
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5101
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5102
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5103
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5104
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5105
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5106
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5107
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5108
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5109
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5110
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5111
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5112
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5113
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5114
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5115
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5116
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5117
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5118
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5119
	}/*function_dt_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5120
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5121
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5122
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5123
 *DT_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5124
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5125
	case function_dt_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5126
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5127
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5128
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5129
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5130
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5131
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5132
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5133
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5134
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5135
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5136
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5137
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5138
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5139
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5140
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5141
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5142
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5143
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5144
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5145
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5146
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5147
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5148
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5149
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5150
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5151
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5152
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5153
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5154
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5155
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5156
	}/*function_dt_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5157
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5158
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5159
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5160
 *DT_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5161
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5162
	case function_dt_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5163
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5164
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5165
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5166
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5167
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5168
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5169
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5170
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5171
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5172
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5173
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5174
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5175
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5176
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5177
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5178
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5179
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5180
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5181
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5182
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5183
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5184
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5185
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5186
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5187
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5188
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5189
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5190
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5191
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5192
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5193
	}/*function_dt_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5194
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5195
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5196
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5197
 *DT_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5198
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5199
	case function_dt_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5200
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5201
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5202
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5203
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5204
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5205
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5206
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5207
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5208
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5209
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5210
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5211
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5212
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5213
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5214
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5215
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5216
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5217
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5218
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5219
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5220
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5221
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5222
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5223
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5224
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5225
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5226
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5227
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5228
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5229
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5230
	}/*function_dt_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5231
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5232
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5233
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5234
 *DT_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5235
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5236
	case function_dt_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5237
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5238
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5239
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5240
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5241
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5242
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5243
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5244
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5245
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5246
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5247
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5248
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5249
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5250
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5251
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5252
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5253
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5254
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5255
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5256
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5257
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5258
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5259
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5260
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5261
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5262
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5263
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5264
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5265
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5266
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5267
	}/*function_dt_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5268
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5269
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5270
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5271
 *DT_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5272
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5273
	case function_dt_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5274
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5275
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5276
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5277
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5278
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5279
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5280
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5281
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5282
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5283
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5284
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5285
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5286
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5287
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5288
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5289
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5290
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5291
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5292
				s4o.print("#error DT_TO_TIME not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5293
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5294
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5295
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5296
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5297
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5298
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5299
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5300
	}/*function_dt_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5301
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5302
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5303
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5304
 *DT_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5305
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5306
	case function_dt_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5307
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5308
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5309
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5310
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5311
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5312
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5313
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5314
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5315
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5316
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5317
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5318
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5319
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5320
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5321
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5322
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5323
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5324
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5325
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5326
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5327
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5328
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5329
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5330
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5331
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5332
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5333
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5334
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5335
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5336
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5337
	}/*function_dt_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5338
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5339
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5340
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5341
 *TOD_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5342
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5343
	case function_tod_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5344
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5345
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5346
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5347
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5348
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5349
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5350
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5351
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5352
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5353
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5354
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5355
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5356
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5357
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5358
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5359
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5360
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5361
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5362
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5363
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5364
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5365
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5366
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5367
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5368
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5369
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5370
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5371
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5372
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5373
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5374
	}/*function_tod_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5375
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5376
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5377
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5378
 *TOD_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5379
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5380
	case function_tod_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5381
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5382
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5383
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5384
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5385
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5386
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5387
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5388
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5389
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5390
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5391
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5392
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5393
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5394
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5395
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5396
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5397
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5398
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5399
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5400
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5401
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5402
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5403
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5404
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5405
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5406
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5407
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5408
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5409
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5410
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5411
	}/*function_tod_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5412
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5413
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5414
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5415
 *TOD_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5416
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5417
	case function_tod_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5418
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5419
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5420
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5421
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5422
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5423
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5424
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5425
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5426
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5427
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5428
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5429
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5430
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5431
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5432
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5433
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5434
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5435
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5436
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5437
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5438
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5439
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5440
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5441
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5442
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5443
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5444
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5445
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5446
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5447
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5448
	}/*function_tod_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5449
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5450
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5451
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5452
 *TOD_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5453
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5454
	case function_tod_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5455
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5456
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5457
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5458
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5459
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5460
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5461
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5462
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5463
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5464
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5465
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5466
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5467
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5468
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5469
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5470
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5471
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5472
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5473
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5474
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5475
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5476
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5477
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5478
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5479
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5480
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5481
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5482
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5483
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5484
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5485
	}/*function_tod_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5486
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5487
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5488
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5489
 *TOD_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5490
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5491
	case function_tod_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5492
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5493
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5494
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5495
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5496
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5497
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5498
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5499
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5500
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5501
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5502
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5503
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5504
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5505
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5506
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5507
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5508
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5509
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5510
				s4o.print("#error TOD_TO_DATE not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5511
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5512
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5513
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5514
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5515
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5516
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5517
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5518
	}/*function_tod_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5519
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5520
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5521
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5522
 *TOD_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5523
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5524
	case function_tod_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5525
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5526
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5527
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5528
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5529
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5530
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5531
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5532
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5533
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5534
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5535
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5536
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5537
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5538
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5539
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5540
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5541
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5542
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5543
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5544
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5545
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5546
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5547
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5548
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5549
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5550
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5551
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5552
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5553
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5554
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5555
	}/*function_tod_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5556
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5557
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5558
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5559
 *TOD_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5560
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5561
	case function_tod_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5562
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5563
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5564
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5565
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5566
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5567
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5568
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5569
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5570
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5571
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5572
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5573
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5574
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5575
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5576
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5577
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5578
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5579
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5580
				s4o.print("#error TOD_TO_DT not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5581
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5582
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5583
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5584
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5585
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5586
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5587
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5588
	}/*function_tod_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5589
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5590
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5591
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5592
 *TOD_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5593
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5594
	case function_tod_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5595
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5596
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5597
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5598
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5599
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5600
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5601
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5602
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5603
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5604
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5605
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5606
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5607
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5608
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5609
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5610
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5611
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5612
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5613
				s4o.print("#error TOD_TO_TOD not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5614
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5615
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5616
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5617
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5618
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5619
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5620
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5621
	}/*function_tod_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5622
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5623
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5624
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5625
 *TOD_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5626
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5627
	case function_tod_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5628
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5629
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5630
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5631
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5632
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5633
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5634
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5635
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5636
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5637
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5638
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5639
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5640
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5641
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5642
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5643
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5644
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5645
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5646
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5647
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5648
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5649
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5650
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5651
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5652
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5653
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5654
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5655
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5656
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5657
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5658
	}/*function_tod_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5659
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5660
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5661
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5662
 *TOD_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5663
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5664
	case function_tod_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5665
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5666
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5667
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5668
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5669
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5670
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5671
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5672
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5673
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5674
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5675
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5676
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5677
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5678
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5679
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5680
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5681
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5682
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5683
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5684
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5685
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5686
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5687
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5688
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5689
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5690
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5691
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5692
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5693
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5694
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5695
	}/*function_tod_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5696
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5697
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5698
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5699
 *TOD_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5700
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5701
	case function_tod_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5702
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5703
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5704
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5705
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5706
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5707
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5708
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5709
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5710
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5711
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5712
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5713
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5714
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5715
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5716
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5717
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5718
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5719
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5720
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5721
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5722
				s4o.print(")string_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5723
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5724
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5725
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5726
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5727
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5728
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5729
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5730
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5731
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5732
	}/*function_tod_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5733
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5734
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5735
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5736
 *TOD_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5737
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5738
	case function_tod_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5739
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5740
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5741
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5742
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5743
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5744
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5745
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5746
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5747
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5748
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5749
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5750
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5751
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5752
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5753
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5754
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5755
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5756
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5757
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5758
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5759
				s4o.print(")string_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5760
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5761
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5762
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5763
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5764
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5765
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5766
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5767
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5768
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5769
	}/*function_tod_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5770
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5771
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5772
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5773
 *TOD_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5774
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5775
	case function_tod_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5776
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5777
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5778
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5779
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5780
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5781
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5782
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5783
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5784
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5785
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5786
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5787
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5788
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5789
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5790
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5791
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5792
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5793
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5794
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5795
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5796
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5797
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5798
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5799
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5800
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5801
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5802
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5803
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5804
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5805
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5806
	}/*function_tod_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5807
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5808
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5809
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5810
 *TOD_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5811
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5812
	case function_tod_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5813
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5814
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5815
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5816
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5817
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5818
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5819
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5820
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5821
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5822
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5823
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5824
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5825
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5826
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5827
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5828
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5829
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5830
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5831
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5832
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5833
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5834
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5835
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5836
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5837
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5838
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5839
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5840
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5841
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5842
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5843
	}/*function_tod_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5844
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5845
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5846
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5847
 *TOD_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5848
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5849
	case function_tod_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5850
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5851
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5852
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5853
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5854
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5855
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5856
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5857
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5858
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5859
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5860
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5861
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5862
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5863
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5864
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5865
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5866
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5867
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5868
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5869
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5870
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5871
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5872
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5873
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5874
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5875
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5876
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5877
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5878
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5879
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5880
	}/*function_tod_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5881
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5882
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5883
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5884
 *TOD_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5885
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5886
	case function_tod_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5887
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5888
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5889
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5890
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5891
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5892
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5893
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5894
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5895
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5896
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5897
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5898
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5899
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5900
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5901
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5902
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5903
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5904
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5905
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5906
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5907
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5908
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5909
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5910
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5911
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5912
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5913
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5914
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5915
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5916
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5917
	}/*function_tod_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5918
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5919
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5920
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5921
 *TOD_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5922
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5923
	case function_tod_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5924
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5925
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5926
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5927
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5928
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5929
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5930
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5931
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5932
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5933
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5934
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5935
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5936
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5937
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5938
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5939
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5940
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5941
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5942
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5943
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5944
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5945
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5946
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5947
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5948
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5949
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5950
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5951
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5952
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5953
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5954
	}/*function_tod_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5955
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5956
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5957
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5958
 *TOD_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5959
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5960
	case function_tod_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5961
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5962
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5963
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5964
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5965
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5966
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5967
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5968
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5969
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5970
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5971
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5972
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5973
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5974
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5975
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5976
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5977
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5978
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5979
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5980
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5981
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5982
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5983
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5984
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5985
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5986
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5987
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5988
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5989
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5990
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5991
	}/*function_tod_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5992
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5993
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5994
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5995
 *TOD_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5996
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5997
	case function_tod_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5998
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  5999
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6000
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6001
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6002
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6003
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6004
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6005
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6006
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6007
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6008
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6009
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6010
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6011
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6012
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6013
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6014
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6015
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6016
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6017
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6018
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6019
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6020
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6021
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6022
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6023
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6024
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6025
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6026
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6027
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6028
	}/*function_tod_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6029
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6030
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6031
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6032
 *TOD_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6033
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6034
	case function_tod_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6035
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6036
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6037
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6038
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6039
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6040
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6041
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6042
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6043
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6044
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6045
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6046
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6047
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6048
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6049
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6050
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6051
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6052
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6053
				s4o.print("#error TOD_TO_TIME not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6054
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6055
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6056
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6057
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6058
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6059
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6060
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6061
	}/*function_tod_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6062
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6063
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6064
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6065
 *TOD_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6066
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6067
	case function_tod_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6068
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6069
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6070
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6071
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6072
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6073
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6074
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6075
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6076
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6077
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6078
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6079
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6080
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6081
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6082
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6083
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6084
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6085
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6086
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6087
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6088
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6089
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6090
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6091
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6092
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6093
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6094
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6095
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6096
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6097
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6098
	}/*function_tod_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6099
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6100
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6101
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6102
 *UDINT_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6103
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6104
	case function_udint_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6105
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6106
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6107
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6108
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6109
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6110
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6111
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6112
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6113
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6114
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6115
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6116
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6117
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6118
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6119
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6120
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6121
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6122
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6123
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6124
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6125
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6126
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6127
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6128
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6129
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6130
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6131
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6132
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6133
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6134
	}/*function_udint_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6135
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6136
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6137
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6138
 *UDINT_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6139
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6140
	case function_udint_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6141
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6142
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6143
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6144
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6145
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6146
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6147
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6148
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6149
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6150
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6151
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6152
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6153
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6154
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6155
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6156
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6157
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6158
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6159
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6160
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6161
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6162
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6163
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6164
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6165
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6166
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6167
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6168
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6169
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6170
	}/*function_udint_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6171
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6172
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6173
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6174
 *UDINT_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6175
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6176
	case function_udint_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6177
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6178
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6179
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6180
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6181
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6182
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6183
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6184
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6185
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6186
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6187
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6188
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6189
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6190
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6191
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6192
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6193
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6194
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6195
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6196
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6197
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6198
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6199
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6200
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6201
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6202
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6203
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6204
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6205
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6206
	}/*function_udint_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6207
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6208
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6209
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6210
 *UDINT_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6211
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6212
	case function_udint_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6213
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6214
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6215
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6216
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6217
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6218
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6219
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6220
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6221
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6222
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6223
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6224
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6225
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6226
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6227
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6228
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6229
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6230
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6231
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6232
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6233
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6234
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6235
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6236
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6237
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6238
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6239
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6240
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6241
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6242
	}/*function_udint_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6243
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6244
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6245
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6246
 *UDINT_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6247
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6248
	case function_udint_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6249
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6250
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6251
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6252
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6253
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6254
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6255
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6256
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6257
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6258
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6259
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6260
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6261
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6262
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6263
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6264
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6265
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6266
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6267
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6268
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6269
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6270
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6271
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6272
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6273
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6274
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6275
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6276
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6277
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6278
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6279
	}/*function_udint_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6280
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6281
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6282
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6283
 *UDINT_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6284
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6285
	case function_udint_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6286
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6287
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6288
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6289
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6290
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6291
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6292
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6293
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6294
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6295
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6296
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6297
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6298
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6299
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6300
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6301
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6302
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6303
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6304
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6305
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6306
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6307
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6308
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6309
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6310
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6311
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6312
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6313
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6314
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6315
	}/*function_udint_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6316
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6317
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6318
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6319
 *UDINT_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6320
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6321
	case function_udint_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6322
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6323
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6324
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6325
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6326
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6327
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6328
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6329
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6330
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6331
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6332
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6333
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6334
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6335
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6336
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6337
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6338
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6339
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6340
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6341
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6342
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6343
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6344
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6345
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6346
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6347
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6348
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6349
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6350
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6351
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6352
	}/*function_udint_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6353
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6354
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6355
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6356
 *UDINT_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6357
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6358
	case function_udint_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6359
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6360
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6361
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6362
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6363
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6364
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6365
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6366
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6367
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6368
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6369
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6370
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6371
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6372
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6373
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6374
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6375
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6376
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6377
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6378
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6379
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6380
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6381
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6382
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6383
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6384
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6385
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6386
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6387
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6388
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6389
	}/*function_udint_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6390
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6391
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6392
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6393
 *UDINT_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6394
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6395
	case function_udint_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6396
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6397
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6398
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6399
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6400
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6401
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6402
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6403
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6404
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6405
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6406
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6407
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6408
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6409
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6410
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6411
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6412
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6413
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6414
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6415
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6416
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6417
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6418
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6419
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6420
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6421
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6422
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6423
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6424
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6425
	}/*function_udint_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6426
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6427
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6428
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6429
 *UDINT_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6430
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6431
	case function_udint_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6432
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6433
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6434
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6435
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6436
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6437
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6438
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6439
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6440
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6441
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6442
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6443
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6444
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6445
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6446
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6447
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6448
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6449
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6450
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6451
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6452
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6453
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6454
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6455
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6456
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6457
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6458
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6459
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6460
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6461
	}/*function_udint_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6462
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6463
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6464
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6465
 *UDINT_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6466
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6467
	case function_udint_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6468
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6469
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6470
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6471
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6472
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6473
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6474
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6475
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6476
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6477
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6478
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6479
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6480
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6481
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6482
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6483
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6484
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6485
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6486
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6487
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6488
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6489
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6490
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6491
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6492
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6493
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6494
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6495
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6496
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6497
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6498
	}/*function_udint_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6499
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6500
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6501
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6502
 *UDINT_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6503
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6504
	case function_udint_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6505
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6506
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6507
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6508
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6509
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6510
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6511
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6512
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6513
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6514
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6515
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6516
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6517
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6518
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6519
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6520
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6521
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6522
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6523
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6524
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6525
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6526
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6527
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6528
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6529
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6530
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6531
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6532
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6533
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6534
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6535
	}/*function_udint_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6536
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6537
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6538
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6539
 *UDINT_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6540
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6541
	case function_udint_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6542
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6543
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6544
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6545
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6546
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6547
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6548
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6549
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6550
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6551
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6552
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6553
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6554
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6555
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6556
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6557
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6558
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6559
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6560
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6561
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6562
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6563
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6564
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6565
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6566
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6567
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6568
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6569
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6570
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6571
	}/*function_udint_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6572
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6573
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6574
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6575
 *UDINT_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6576
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6577
	case function_udint_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6578
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6579
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6580
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6581
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6582
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6583
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6584
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6585
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6586
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6587
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6588
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6589
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6590
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6591
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6592
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6593
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6594
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6595
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6596
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6597
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6598
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6599
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6600
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6601
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6602
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6603
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6604
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6605
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6606
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6607
	}/*function_udint_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6608
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6609
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6610
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6611
 *UDINT_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6612
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6613
	case function_udint_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6614
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6615
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6616
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6617
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6618
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6619
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6620
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6621
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6622
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6623
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6624
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6625
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6626
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6627
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6628
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6629
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6630
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6631
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6632
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6633
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6634
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6635
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6636
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6637
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6638
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6639
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6640
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6641
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6642
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6643
	}/*function_udint_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6644
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6645
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6646
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6647
 *UDINT_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6648
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6649
	case function_udint_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6650
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6651
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6652
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6653
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6654
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6655
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6656
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6657
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6658
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6659
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6660
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6661
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6662
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6663
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6664
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6665
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6666
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6667
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6668
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6669
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6670
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6671
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6672
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6673
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6674
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6675
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6676
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6677
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6678
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6679
	}/*function_udint_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6680
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6681
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6682
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6683
 *UDINT_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6684
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6685
	case function_udint_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6686
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6687
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6688
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6689
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6690
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6691
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6692
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6693
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6694
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6695
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6696
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6697
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6698
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6699
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6700
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6701
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6702
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6703
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6704
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6705
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6706
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6707
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6708
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6709
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6710
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6711
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6712
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6713
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6714
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6715
	}/*function_udint_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6716
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6717
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6718
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6719
 *UDINT_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6720
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6721
	case function_udint_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6722
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6723
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6724
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6725
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6726
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6727
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6728
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6729
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6730
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6731
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6732
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6733
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6734
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6735
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6736
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6737
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6738
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6739
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6740
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6741
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6742
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6743
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6744
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6745
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6746
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6747
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6748
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6749
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6750
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6751
	}/*function_udint_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6752
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6753
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6754
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6755
 *UDINT_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6756
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6757
	case function_udint_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6758
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6759
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6760
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6761
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6762
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6763
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6764
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6765
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6766
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6767
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6768
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6769
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6770
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6771
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6772
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6773
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6774
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6775
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6776
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6777
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6778
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6779
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6780
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6781
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6782
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6783
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6784
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6785
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6786
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6787
	}/*function_udint_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6788
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6789
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6790
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6791
 *UDINT_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6792
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6793
	case function_udint_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6794
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6795
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6796
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6797
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6798
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6799
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6800
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6801
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6802
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6803
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6804
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6805
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6806
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6807
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6808
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6809
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6810
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6811
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6812
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6813
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6814
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6815
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6816
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6817
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6818
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6819
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6820
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6821
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6822
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6823
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6824
	}/*function_udint_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6825
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6826
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6827
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6828
 *UDINT_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6829
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6830
	case function_udint_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6831
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6832
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6833
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6834
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6835
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6836
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6837
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6838
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6839
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6840
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6841
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6842
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6843
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6844
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6845
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6846
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6847
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6848
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6849
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6850
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6851
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6852
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6853
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6854
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6855
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6856
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6857
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6858
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6859
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6860
	}/*function_udint_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6861
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6862
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6863
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6864
 *WORD_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6865
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6866
	case function_word_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6867
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6868
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6869
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6870
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6871
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6872
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6873
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6874
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6875
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6876
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6877
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6878
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6879
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6880
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6881
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6882
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6883
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6884
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6885
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6886
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6887
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6888
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6889
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6890
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6891
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6892
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6893
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6894
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6895
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6896
	}/*function_word_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6897
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6898
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6899
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6900
 *WORD_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6901
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6902
	case function_word_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6903
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6904
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6905
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6906
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6907
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6908
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6909
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6910
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6911
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6912
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6913
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6914
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6915
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6916
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6917
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6918
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6919
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6920
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6921
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6922
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6923
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6924
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6925
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6926
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6927
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6928
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6929
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6930
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6931
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6932
	}/*function_word_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6933
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6934
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6935
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6936
 *WORD_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6937
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6938
	case function_word_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6939
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6940
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6941
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6942
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6943
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6944
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6945
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6946
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6947
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6948
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6949
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6950
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6951
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6952
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6953
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6954
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6955
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6956
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6957
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6958
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6959
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6960
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6961
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6962
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6963
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6964
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6965
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6966
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6967
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6968
	}/*function_word_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6969
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6970
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6971
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6972
 *WORD_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6973
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6974
	case function_word_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6975
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6976
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6977
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6978
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6979
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6980
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6981
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6982
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6983
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6984
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6985
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6986
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6987
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6988
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6989
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6990
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6991
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6992
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6993
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6994
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6995
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6996
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6997
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6998
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  6999
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7000
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7001
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7002
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7003
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7004
	}/*function_word_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7005
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7006
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7007
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7008
 *WORD_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7009
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7010
	case function_word_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7011
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7012
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7013
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7014
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7015
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7016
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7017
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7018
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7019
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7020
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7021
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7022
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7023
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7024
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7025
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7026
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7027
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7028
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7029
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7030
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7031
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7032
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7033
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7034
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7035
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7036
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7037
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7038
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7039
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7040
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7041
	}/*function_word_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7042
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7043
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7044
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7045
 *WORD_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7046
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7047
	case function_word_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7048
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7049
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7050
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7051
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7052
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7053
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7054
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7055
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7056
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7057
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7058
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7059
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7060
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7061
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7062
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7063
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7064
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7065
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7066
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7067
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7068
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7069
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7070
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7071
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7072
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7073
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7074
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7075
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7076
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7077
	}/*function_word_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7078
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7079
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7080
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7081
 *WORD_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7082
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7083
	case function_word_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7084
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7085
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7086
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7087
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7088
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7089
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7090
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7091
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7092
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7093
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7094
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7095
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7096
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7097
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7098
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7099
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7100
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7101
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7102
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7103
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7104
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7105
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7106
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7107
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7108
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7109
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7110
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7111
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7112
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7113
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7114
	}/*function_word_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7115
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7116
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7117
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7118
 *WORD_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7119
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7120
	case function_word_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7121
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7122
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7123
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7124
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7125
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7126
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7127
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7128
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7129
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7130
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7131
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7132
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7133
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7134
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7135
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7136
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7137
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7138
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7139
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7140
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7141
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7142
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7143
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7144
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7145
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7146
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7147
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7148
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7149
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7150
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7151
	}/*function_word_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7152
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7153
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7154
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7155
 *WORD_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7156
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7157
	case function_word_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7158
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7159
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7160
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7161
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7162
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7163
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7164
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7165
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7166
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7167
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7168
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7169
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7170
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7171
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7172
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7173
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7174
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7175
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7176
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7177
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7178
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7179
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7180
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7181
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7182
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7183
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7184
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7185
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7186
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7187
	}/*function_word_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7188
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7189
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7190
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7191
 *WORD_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7192
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7193
	case function_word_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7194
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7195
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7196
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7197
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7198
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7199
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7200
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7201
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7202
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7203
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7204
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7205
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7206
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7207
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7208
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7209
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7210
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7211
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7212
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7213
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7214
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7215
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7216
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7217
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7218
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7219
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7220
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7221
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7222
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7223
	}/*function_word_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7224
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7225
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7226
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7227
 *WORD_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7228
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7229
	case function_word_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7230
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7231
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7232
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7233
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7234
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7235
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7236
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7237
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7238
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7239
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7240
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7241
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7242
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7243
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7244
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7245
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7246
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7247
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7248
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7249
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7250
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7251
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7252
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7253
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7254
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7255
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7256
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7257
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7258
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7259
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7260
	}/*function_word_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7261
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7262
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7263
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7264
 *WORD_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7265
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7266
	case function_word_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7267
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7268
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7269
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7270
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7271
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7272
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7273
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7274
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7275
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7276
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7277
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7278
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7279
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7280
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7281
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7282
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7283
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7284
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7285
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7286
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7287
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7288
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7289
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7290
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7291
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7292
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7293
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7294
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7295
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7296
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7297
	}/*function_word_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7298
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7299
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7300
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7301
 *WORD_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7302
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7303
	case function_word_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7304
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7305
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7306
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7307
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7308
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7309
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7310
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7311
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7312
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7313
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7314
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7315
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7316
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7317
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7318
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7319
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7320
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7321
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7322
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7323
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7324
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7325
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7326
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7327
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7328
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7329
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7330
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7331
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7332
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7333
	}/*function_word_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7334
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7335
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7336
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7337
 *WORD_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7338
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7339
	case function_word_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7340
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7341
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7342
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7343
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7344
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7345
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7346
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7347
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7348
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7349
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7350
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7351
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7352
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7353
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7354
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7355
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7356
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7357
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7358
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7359
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7360
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7361
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7362
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7363
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7364
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7365
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7366
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7367
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7368
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7369
	}/*function_word_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7370
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7371
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7372
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7373
 *WORD_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7374
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7375
	case function_word_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7376
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7377
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7378
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7379
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7380
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7381
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7382
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7383
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7384
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7385
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7386
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7387
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7388
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7389
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7390
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7391
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7392
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7393
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7394
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7395
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7396
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7397
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7398
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7399
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7400
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7401
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7402
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7403
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7404
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7405
	}/*function_word_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7406
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7407
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7408
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7409
 *WORD_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7410
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7411
	case function_word_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7412
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7413
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7414
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7415
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7416
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7417
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7418
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7419
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7420
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7421
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7422
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7423
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7424
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7425
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7426
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7427
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7428
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7429
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7430
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7431
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7432
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7433
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7434
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7435
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7436
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7437
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7438
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7439
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7440
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7441
	}/*function_word_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7442
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7443
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7444
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7445
 *WORD_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7446
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7447
	case function_word_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7448
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7449
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7450
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7451
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7452
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7453
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7454
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7455
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7456
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7457
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7458
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7459
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7460
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7461
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7462
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7463
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7464
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7465
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7466
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7467
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7468
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7469
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7470
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7471
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7472
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7473
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7474
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7475
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7476
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7477
	}/*function_word_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7478
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7479
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7480
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7481
 *WORD_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7482
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7483
	case function_word_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7484
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7485
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7486
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7487
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7488
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7489
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7490
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7491
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7492
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7493
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7494
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7495
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7496
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7497
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7498
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7499
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7500
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7501
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7502
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7503
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7504
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7505
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7506
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7507
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7508
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7509
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7510
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7511
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7512
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7513
	}/*function_word_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7514
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7515
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7516
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7517
 *WORD_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7518
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7519
	case function_word_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7520
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7521
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7522
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7523
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7524
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7525
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7526
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7527
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7528
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7529
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7530
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7531
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7532
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7533
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7534
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7535
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7536
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7537
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7538
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7539
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7540
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7541
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7542
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7543
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7544
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7545
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7546
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7547
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7548
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7549
	}/*function_word_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7550
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7551
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7552
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7553
 *WORD_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7554
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7555
	case function_word_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7556
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7557
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7558
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7559
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7560
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7561
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7562
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7563
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7564
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7565
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7566
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7567
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7568
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7569
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7570
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7571
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7572
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7573
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7574
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7575
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7576
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7577
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7578
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7579
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7580
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7581
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7582
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7583
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7584
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7585
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7586
	}/*function_word_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7587
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7588
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7589
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7590
 *WORD_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7591
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7592
	case function_word_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7593
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7594
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7595
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7596
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7597
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7598
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7599
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7600
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7601
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7602
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7603
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7604
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7605
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7606
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7607
			if (typeid(*last_type_symbol) == typeid(word_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7608
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7609
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7610
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7611
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7612
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7613
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7614
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7615
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7616
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7617
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7618
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7619
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7620
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7621
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7622
	}/*function_word_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7623
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7624
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7625
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7626
 *WSTRING_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7627
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7628
	case function_wstring_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7629
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7630
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7631
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7632
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7633
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7634
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7635
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7636
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7637
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7638
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7639
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7640
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7641
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7642
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7643
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7644
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7645
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7646
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7647
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7648
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7649
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7650
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7651
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7652
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7653
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7654
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7655
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7656
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7657
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7658
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7659
	}/*function_wstring_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7660
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7661
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7662
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7663
 *WSTRING_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7664
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7665
	case function_wstring_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7666
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7667
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7668
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7669
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7670
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7671
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7672
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7673
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7674
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7675
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7676
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7677
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7678
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7679
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7680
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7681
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7682
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7683
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7684
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7685
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7686
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7687
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7688
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7689
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7690
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7691
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7692
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7693
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7694
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7695
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7696
	}/*function_wstring_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7697
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7698
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7699
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7700
 *WSTRING_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7701
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7702
	case function_wstring_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7703
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7704
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7705
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7706
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7707
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7708
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7709
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7710
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7711
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7712
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7713
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7714
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7715
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7716
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7717
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7718
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7719
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7720
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7721
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7722
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7723
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7724
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7725
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7726
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7727
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7728
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7729
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7730
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7731
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7732
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7733
	}/*function_wstring_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7734
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7735
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7736
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7737
 *WSTRING_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7738
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7739
	case function_wstring_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7740
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7741
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7742
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7743
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7744
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7745
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7746
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7747
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7748
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7749
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7750
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7751
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7752
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7753
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7754
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7755
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7756
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7757
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7758
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7759
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7760
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7761
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7762
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7763
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7764
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7765
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7766
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7767
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7768
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7769
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7770
	}/*function_wstring_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7771
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7772
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7773
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7774
 *WSTRING_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7775
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7776
	case function_wstring_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7777
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7778
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7779
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7780
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7781
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7782
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7783
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7784
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7785
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7786
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7787
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7788
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7789
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7790
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7791
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7792
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7793
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7794
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7795
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7796
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7797
				s4o.print(")time_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7798
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7799
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7800
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7801
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7802
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7803
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7804
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7805
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7806
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7807
	}/*function_wstring_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7808
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7809
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7810
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7811
 *WSTRING_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7812
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7813
	case function_wstring_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7814
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7815
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7816
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7817
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7818
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7819
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7820
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7821
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7822
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7823
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7824
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7825
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7826
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7827
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7828
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7829
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7830
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7831
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7832
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7833
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7834
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7835
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7836
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7837
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7838
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7839
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7840
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7841
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7842
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7843
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7844
	}/*function_wstring_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7845
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7846
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7847
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7848
 *WSTRING_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7849
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7850
	case function_wstring_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7851
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7852
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7853
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7854
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7855
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7856
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7857
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7858
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7859
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7860
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7861
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7862
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7863
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7864
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7865
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7866
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7867
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7868
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7869
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7870
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7871
				s4o.print(")time_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7872
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7873
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7874
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7875
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7876
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7877
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7878
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7879
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7880
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7881
	}/*function_wstring_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7882
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7883
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7884
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7885
 *WSTRING_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7886
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7887
	case function_wstring_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7888
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7889
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7890
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7891
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7892
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7893
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7894
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7895
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7896
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7897
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7898
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7899
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7900
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7901
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7902
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7903
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7904
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7905
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7906
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7907
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7908
				s4o.print(")time_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7909
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7910
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7911
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7912
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7913
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7914
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7915
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7916
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7917
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7918
	}/*function_wstring_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7919
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7920
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7921
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7922
 *WSTRING_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7923
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7924
	case function_wstring_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7925
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7926
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7927
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7928
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7929
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7930
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7931
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7932
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7933
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7934
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7935
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7936
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7937
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7938
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7939
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7940
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7941
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7942
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7943
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7944
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7945
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7946
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7947
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7948
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7949
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7950
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7951
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7952
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7953
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7954
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7955
	}/*function_wstring_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7956
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7957
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7958
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7959
 *WSTRING_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7960
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7961
	case function_wstring_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7962
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7963
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7964
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7965
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7966
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7967
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7968
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7969
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7970
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7971
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7972
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7973
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7974
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7975
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7976
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7977
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7978
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7979
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7980
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7981
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7982
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7983
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7984
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7985
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7986
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7987
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7988
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7989
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7990
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7991
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7992
	}/*function_wstring_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7993
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7994
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7995
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7996
 *WSTRING_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7997
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7998
	case function_wstring_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  7999
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8000
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8001
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8002
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8003
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8004
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8005
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8006
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8007
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8008
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8009
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8010
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8011
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8012
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8013
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8014
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8015
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8016
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8017
				s4o.print("#error WSTRING_TO_WSTRING not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8018
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8019
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8020
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8021
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8022
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8023
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8024
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8025
	}/*function_wstring_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8026
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8027
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8028
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8029
 *WSTRING_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8030
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8031
	case function_wstring_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8032
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8033
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8034
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8035
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8036
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8037
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8038
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8039
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8040
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8041
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8042
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8043
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8044
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8045
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8046
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8047
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8048
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8049
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8050
				s4o.print("#error WSTRING_TO_STRING not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8051
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8052
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8053
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8054
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8055
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8056
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8057
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8058
	}/*function_wstring_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8059
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8060
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8061
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8062
 *WSTRING_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8063
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8064
	case function_wstring_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8065
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8066
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8067
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8068
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8069
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8070
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8071
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8072
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8073
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8074
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8075
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8076
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8077
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8078
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8079
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8080
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8081
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8082
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8083
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8084
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8085
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8086
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8087
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8088
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8089
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8090
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8091
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8092
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8093
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8094
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8095
	}/*function_wstring_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8096
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8097
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8098
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8099
 *WSTRING_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8100
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8101
	case function_wstring_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8102
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8103
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8104
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8105
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8106
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8107
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8108
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8109
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8110
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8111
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8112
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8113
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8114
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8115
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8116
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8117
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8118
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8119
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8120
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8121
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8122
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8123
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8124
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8125
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8126
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8127
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8128
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8129
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8130
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8131
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8132
	}/*function_wstring_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8133
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8134
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8135
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8136
 *WSTRING_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8137
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8138
	case function_wstring_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8139
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8140
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8141
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8142
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8143
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8144
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8145
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8146
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8147
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8148
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8149
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8150
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8151
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8152
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8153
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8154
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8155
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8156
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8157
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8158
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8159
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8160
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8161
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8162
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8163
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8164
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8165
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8166
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8167
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8168
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8169
	}/*function_wstring_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8170
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8171
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8172
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8173
 *WSTRING_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8174
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8175
	case function_wstring_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8176
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8177
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8178
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8179
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8180
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8181
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8182
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8183
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8184
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8185
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8186
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8187
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8188
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8189
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8190
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8191
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8192
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8193
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8194
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8195
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8196
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8197
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8198
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8199
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8200
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8201
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8202
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8203
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8204
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8205
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8206
	}/*function_wstring_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8207
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8208
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8209
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8210
 *WSTRING_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8211
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8212
	case function_wstring_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8213
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8214
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8215
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8216
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8217
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8218
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8219
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8220
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8221
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8222
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8223
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8224
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8225
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8226
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8227
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8228
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8229
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8230
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8231
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8232
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8233
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8234
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8235
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8236
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8237
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8238
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8239
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8240
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8241
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8242
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8243
	}/*function_wstring_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8244
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8245
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8246
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8247
 *WSTRING_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8248
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8249
	case function_wstring_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8250
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8251
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8252
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8253
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8254
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8255
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8256
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8257
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8258
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8259
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8260
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8261
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8262
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8263
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8264
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8265
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8266
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8267
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8268
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8269
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8270
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8271
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8272
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8273
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8274
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8275
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8276
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8277
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8278
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8279
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8280
	}/*function_wstring_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8281
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8282
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8283
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8284
 *WSTRING_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8285
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8286
	case function_wstring_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8287
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8288
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8289
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8290
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8291
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8292
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8293
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8294
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8295
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8296
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8297
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8298
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8299
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8300
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8301
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8302
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8303
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8304
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8305
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8306
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8307
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8308
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8309
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8310
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8311
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8312
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8313
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8314
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8315
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8316
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8317
	}/*function_wstring_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8318
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8319
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8320
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8321
 *WSTRING_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8322
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8323
	case function_wstring_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8324
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8325
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8326
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8327
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8328
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8329
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8330
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8331
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8332
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8333
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8334
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8335
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8336
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8337
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8338
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8339
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8340
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8341
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8342
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8343
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8344
				s4o.print(")time_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8345
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8346
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8347
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8348
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8349
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8350
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8351
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8352
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8353
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8354
	}/*function_wstring_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8355
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8356
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8357
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8358
 *WSTRING_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8359
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8360
	case function_wstring_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8361
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8362
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8363
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8364
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8365
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8366
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8367
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8368
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8369
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8370
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8371
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8372
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8373
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8374
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8375
			if (typeid(*last_type_symbol) == typeid(wstring_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8376
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8377
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8378
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8379
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8380
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8381
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8382
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8383
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8384
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8385
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8386
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8387
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8388
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8389
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8390
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8391
	}/*function_wstring_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8392
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8393
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8394
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8395
 *STRING_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8396
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8397
	case function_string_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8398
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8399
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8400
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8401
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8402
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8403
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8404
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8405
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8406
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8407
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8408
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8409
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8410
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8411
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8412
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8413
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8414
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8415
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8416
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8417
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8418
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8419
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8420
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8421
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8422
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8423
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8424
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8425
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8426
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8427
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8428
	}/*function_string_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8429
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8430
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8431
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8432
 *STRING_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8433
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8434
	case function_string_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8435
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8436
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8437
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8438
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8439
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8440
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8441
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8442
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8443
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8444
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8445
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8446
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8447
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8448
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8449
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8450
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8451
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8452
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8453
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8454
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8455
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8456
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8457
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8458
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8459
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8460
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8461
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8462
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8463
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8464
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8465
	}/*function_string_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8466
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8467
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8468
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8469
 *STRING_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8470
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8471
	case function_string_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8472
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8473
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8474
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8475
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8476
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8477
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8478
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8479
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8480
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8481
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8482
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8483
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8484
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8485
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8486
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8487
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8488
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8489
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8490
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8491
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8492
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8493
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8494
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8495
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8496
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8497
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8498
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8499
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8500
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8501
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8502
	}/*function_string_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8503
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8504
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8505
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8506
 *STRING_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8507
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8508
	case function_string_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8509
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8510
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8511
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8512
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8513
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8514
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8515
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8516
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8517
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8518
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8519
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8520
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8521
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8522
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8523
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8524
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8525
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8526
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8527
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8528
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8529
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8530
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8531
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8532
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8533
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8534
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8535
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8536
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8537
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8538
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8539
	}/*function_string_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8540
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8541
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8542
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8543
 *STRING_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8544
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8545
	case function_string_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8546
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8547
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8548
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8549
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8550
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8551
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8552
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8553
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8554
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8555
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8556
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8557
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8558
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8559
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8560
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8561
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8562
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8563
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8564
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8565
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8566
				s4o.print(")time_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8567
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8568
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8569
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8570
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8571
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8572
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8573
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8574
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8575
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8576
	}/*function_string_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8577
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8578
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8579
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8580
 *STRING_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8581
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8582
	case function_string_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8583
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8584
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8585
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8586
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8587
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8588
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8589
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8590
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8591
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8592
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8593
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8594
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8595
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8596
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8597
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8598
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8599
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8600
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8601
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8602
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8603
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8604
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8605
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8606
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8607
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8608
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8609
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8610
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8611
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8612
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8613
	}/*function_string_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8614
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8615
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8616
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8617
 *STRING_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8618
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8619
	case function_string_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8620
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8621
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8622
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8623
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8624
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8625
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8626
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8627
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8628
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8629
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8630
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8631
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8632
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8633
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8634
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8635
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8636
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8637
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8638
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8639
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8640
				s4o.print(")time_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8641
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8642
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8643
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8644
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8645
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8646
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8647
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8648
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8649
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8650
	}/*function_string_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8651
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8652
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8653
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8654
 *STRING_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8655
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8656
	case function_string_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8657
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8658
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8659
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8660
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8661
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8662
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8663
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8664
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8665
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8666
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8667
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8668
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8669
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8670
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8671
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8672
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8673
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8674
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8675
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8676
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8677
				s4o.print(")time_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8678
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8679
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8680
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8681
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8682
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8683
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8684
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8685
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8686
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8687
	}/*function_string_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8688
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8689
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8690
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8691
 *STRING_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8692
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8693
	case function_string_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8694
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8695
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8696
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8697
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8698
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8699
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8700
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8701
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8702
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8703
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8704
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8705
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8706
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8707
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8708
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8709
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8710
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8711
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8712
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8713
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8714
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8715
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8716
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8717
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8718
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8719
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8720
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8721
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8722
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8723
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8724
	}/*function_string_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8725
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8726
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8727
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8728
 *STRING_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8729
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8730
	case function_string_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8731
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8732
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8733
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8734
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8735
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8736
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8737
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8738
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8739
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8740
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8741
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8742
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8743
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8744
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8745
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8746
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8747
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8748
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8749
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8750
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8751
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8752
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8753
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8754
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8755
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8756
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8757
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8758
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8759
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8760
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8761
	}/*function_string_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8762
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8763
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8764
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8765
 *STRING_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8766
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8767
	case function_string_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8768
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8769
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8770
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8771
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8772
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8773
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8774
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8775
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8776
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8777
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8778
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8779
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8780
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8781
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8782
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8783
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8784
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8785
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8786
				s4o.print("#error STRING_TO_WSTRING not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8787
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8788
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8789
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8790
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8791
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8792
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8793
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8794
	}/*function_string_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8795
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8796
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8797
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8798
 *STRING_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8799
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8800
	case function_string_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8801
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8802
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8803
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8804
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8805
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8806
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8807
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8808
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8809
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8810
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8811
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8812
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8813
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8814
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8815
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8816
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8817
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8818
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8819
				s4o.print("#error STRING_TO_STRING not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8820
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8821
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8822
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8823
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8824
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8825
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8826
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8827
	}/*function_string_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8828
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8829
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8830
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8831
 *STRING_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8832
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8833
	case function_string_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8834
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8835
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8836
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8837
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8838
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8839
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8840
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8841
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8842
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8843
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8844
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8845
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8846
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8847
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8848
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8849
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8850
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8851
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8852
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8853
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8854
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8855
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8856
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8857
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8858
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8859
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8860
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8861
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8862
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8863
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8864
	}/*function_string_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8865
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8866
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8867
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8868
 *STRING_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8869
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8870
	case function_string_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8871
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8872
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8873
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8874
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8875
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8876
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8877
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8878
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8879
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8880
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8881
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8882
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8883
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8884
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8885
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8886
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8887
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8888
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8889
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8890
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8891
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8892
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8893
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8894
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8895
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8896
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8897
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8898
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8899
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8900
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8901
	}/*function_string_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8902
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8903
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8904
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8905
 *STRING_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8906
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8907
	case function_string_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8908
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8909
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8910
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8911
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8912
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8913
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8914
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8915
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8916
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8917
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8918
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8919
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8920
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8921
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8922
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8923
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8924
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8925
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8926
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8927
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8928
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8929
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8930
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8931
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8932
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8933
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8934
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8935
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8936
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8937
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8938
	}/*function_string_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8939
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8940
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8941
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8942
 *STRING_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8943
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8944
	case function_string_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8945
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8946
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8947
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8948
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8949
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8950
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8951
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8952
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8953
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8954
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8955
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8956
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8957
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8958
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8959
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8960
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8961
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8962
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8963
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8964
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8965
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8966
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8967
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8968
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8969
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8970
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8971
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8972
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8973
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8974
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8975
	}/*function_string_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8976
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8977
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8978
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8979
 *STRING_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8980
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8981
	case function_string_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8982
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8983
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8984
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8985
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8986
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8987
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8988
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8989
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8990
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8991
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8992
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8993
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8994
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8995
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8996
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8997
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8998
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  8999
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9000
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9001
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9002
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9003
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9004
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9005
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9006
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9007
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9008
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9009
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9010
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9011
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9012
	}/*function_string_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9013
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9014
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9015
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9016
 *STRING_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9017
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9018
	case function_string_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9019
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9020
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9021
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9022
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9023
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9024
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9025
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9026
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9027
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9028
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9029
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9030
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9031
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9032
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9033
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9034
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9035
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9036
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9037
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9038
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9039
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9040
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9041
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9042
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9043
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9044
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9045
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9046
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9047
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9048
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9049
	}/*function_string_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9050
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9051
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9052
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9053
 *STRING_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9054
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9055
	case function_string_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9056
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9057
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9058
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9059
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9060
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9061
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9062
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9063
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9064
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9065
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9066
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9067
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9068
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9069
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9070
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9071
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9072
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9073
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9074
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9075
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9076
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9077
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9078
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9079
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9080
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9081
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9082
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9083
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9084
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9085
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9086
	}/*function_string_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9087
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9088
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9089
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9090
 *STRING_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9091
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9092
	case function_string_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9093
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9094
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9095
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9096
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9097
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9098
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9099
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9100
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9101
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9102
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9103
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9104
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9105
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9106
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9107
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9108
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9109
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9110
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9111
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9112
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9113
				s4o.print(")time_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9114
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9115
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9116
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9117
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9118
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9119
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9120
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9121
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9122
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9123
	}/*function_string_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9124
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9125
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9126
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9127
 *STRING_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9128
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9129
	case function_string_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9130
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9131
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9132
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9133
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9134
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9135
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9136
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9137
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9138
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9139
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9140
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9141
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9142
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9143
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9144
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9145
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9146
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9147
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9148
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9149
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9150
				s4o.print(")int_to_string(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9151
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9152
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9153
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9154
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9155
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9156
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9157
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9158
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9159
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9160
	}/*function_string_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9161
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9162
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9163
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9164
 *LWORD_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9165
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9166
	case function_lword_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9167
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9168
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9169
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9170
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9171
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9172
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9173
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9174
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9175
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9176
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9177
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9178
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9179
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9180
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9181
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9182
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9183
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9184
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9185
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9186
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9187
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9188
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9189
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9190
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9191
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9192
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9193
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9194
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9195
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9196
	}/*function_lword_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9197
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9198
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9199
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9200
 *LWORD_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9201
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9202
	case function_lword_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9203
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9204
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9205
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9206
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9207
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9208
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9209
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9210
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9211
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9212
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9213
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9214
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9215
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9216
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9217
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9218
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9219
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9220
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9221
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9222
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9223
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9224
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9225
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9226
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9227
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9228
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9229
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9230
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9231
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9232
	}/*function_lword_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9233
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9234
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9235
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9236
 *LWORD_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9237
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9238
	case function_lword_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9239
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9240
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9241
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9242
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9243
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9244
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9245
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9246
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9247
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9248
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9249
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9250
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9251
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9252
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9253
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9254
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9255
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9256
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9257
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9258
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9259
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9260
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9261
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9262
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9263
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9264
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9265
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9266
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9267
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9268
	}/*function_lword_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9269
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9270
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9271
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9272
 *LWORD_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9273
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9274
	case function_lword_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9275
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9276
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9277
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9278
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9279
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9280
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9281
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9282
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9283
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9284
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9285
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9286
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9287
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9288
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9289
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9290
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9291
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9292
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9293
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9294
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9295
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9296
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9297
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9298
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9299
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9300
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9301
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9302
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9303
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9304
	}/*function_lword_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9305
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9306
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9307
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9308
 *LWORD_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9309
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9310
	case function_lword_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9311
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9312
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9313
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9314
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9315
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9316
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9317
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9318
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9319
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9320
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9321
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9322
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9323
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9324
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9325
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9326
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9327
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9328
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9329
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9330
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9331
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9332
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9333
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9334
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9335
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9336
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9337
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9338
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9339
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9340
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9341
	}/*function_lword_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9342
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9343
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9344
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9345
 *LWORD_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9346
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9347
	case function_lword_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9348
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9349
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9350
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9351
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9352
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9353
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9354
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9355
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9356
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9357
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9358
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9359
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9360
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9361
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9362
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9363
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9364
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9365
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9366
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9367
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9368
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9369
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9370
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9371
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9372
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9373
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9374
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9375
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9376
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9377
	}/*function_lword_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9378
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9379
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9380
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9381
 *LWORD_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9382
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9383
	case function_lword_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9384
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9385
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9386
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9387
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9388
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9389
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9390
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9391
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9392
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9393
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9394
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9395
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9396
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9397
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9398
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9399
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9400
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9401
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9402
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9403
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9404
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9405
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9406
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9407
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9408
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9409
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9410
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9411
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9412
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9413
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9414
	}/*function_lword_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9415
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9416
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9417
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9418
 *LWORD_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9419
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9420
	case function_lword_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9421
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9422
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9423
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9424
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9425
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9426
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9427
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9428
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9429
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9430
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9431
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9432
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9433
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9434
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9435
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9436
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9437
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9438
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9439
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9440
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9441
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9442
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9443
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9444
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9445
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9446
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9447
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9448
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9449
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9450
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9451
	}/*function_lword_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9452
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9453
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9454
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9455
 *LWORD_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9456
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9457
	case function_lword_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9458
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9459
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9460
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9461
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9462
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9463
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9464
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9465
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9466
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9467
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9468
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9469
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9470
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9471
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9472
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9473
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9474
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9475
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9476
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9477
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9478
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9479
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9480
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9481
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9482
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9483
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9484
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9485
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9486
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9487
	}/*function_lword_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9488
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9489
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9490
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9491
 *LWORD_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9492
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9493
	case function_lword_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9494
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9495
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9496
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9497
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9498
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9499
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9500
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9501
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9502
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9503
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9504
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9505
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9506
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9507
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9508
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9509
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9510
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9511
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9512
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9513
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9514
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9515
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9516
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9517
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9518
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9519
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9520
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9521
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9522
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9523
	}/*function_lword_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9524
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9525
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9526
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9527
 *LWORD_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9528
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9529
	case function_lword_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9530
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9531
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9532
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9533
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9534
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9535
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9536
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9537
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9538
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9539
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9540
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9541
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9542
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9543
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9544
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9545
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9546
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9547
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9548
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9549
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9550
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9551
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9552
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9553
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9554
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9555
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9556
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9557
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9558
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9559
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9560
	}/*function_lword_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9561
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9562
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9563
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9564
 *LWORD_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9565
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9566
	case function_lword_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9567
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9568
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9569
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9570
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9571
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9572
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9573
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9574
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9575
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9576
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9577
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9578
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9579
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9580
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9581
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9582
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9583
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9584
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9585
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9586
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9587
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9588
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9589
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9590
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9591
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9592
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9593
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9594
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9595
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9596
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9597
	}/*function_lword_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9598
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9599
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9600
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9601
 *LWORD_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9602
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9603
	case function_lword_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9604
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9605
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9606
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9607
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9608
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9609
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9610
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9611
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9612
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9613
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9614
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9615
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9616
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9617
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9618
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9619
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9620
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9621
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9622
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9623
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9624
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9625
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9626
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9627
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9628
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9629
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9630
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9631
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9632
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9633
	}/*function_lword_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9634
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9635
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9636
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9637
 *LWORD_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9638
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9639
	case function_lword_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9640
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9641
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9642
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9643
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9644
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9645
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9646
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9647
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9648
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9649
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9650
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9651
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9652
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9653
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9654
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9655
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9656
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9657
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9658
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9659
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9660
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9661
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9662
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9663
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9664
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9665
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9666
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9667
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9668
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9669
	}/*function_lword_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9670
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9671
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9672
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9673
 *LWORD_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9674
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9675
	case function_lword_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9676
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9677
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9678
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9679
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9680
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9681
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9682
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9683
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9684
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9685
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9686
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9687
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9688
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9689
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9690
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9691
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9692
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9693
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9694
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9695
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9696
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9697
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9698
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9699
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9700
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9701
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9702
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9703
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9704
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9705
	}/*function_lword_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9706
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9707
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9708
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9709
 *LWORD_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9710
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9711
	case function_lword_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9712
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9713
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9714
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9715
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9716
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9717
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9718
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9719
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9720
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9721
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9722
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9723
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9724
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9725
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9726
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9727
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9728
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9729
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9730
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9731
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9732
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9733
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9734
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9735
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9736
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9737
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9738
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9739
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9740
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9741
	}/*function_lword_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9742
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9743
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9744
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9745
 *LWORD_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9746
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9747
	case function_lword_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9748
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9749
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9750
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9751
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9752
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9753
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9754
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9755
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9756
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9757
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9758
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9759
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9760
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9761
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9762
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9763
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9764
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9765
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9766
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9767
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9768
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9769
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9770
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9771
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9772
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9773
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9774
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9775
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9776
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9777
	}/*function_lword_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9778
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9779
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9780
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9781
 *LWORD_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9782
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9783
	case function_lword_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9784
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9785
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9786
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9787
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9788
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9789
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9790
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9791
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9792
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9793
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9794
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9795
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9796
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9797
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9798
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9799
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9800
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9801
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9802
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9803
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9804
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9805
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9806
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9807
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9808
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9809
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9810
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9811
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9812
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9813
	}/*function_lword_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9814
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9815
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9816
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9817
 *LWORD_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9818
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9819
	case function_lword_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9820
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9821
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9822
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9823
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9824
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9825
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9826
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9827
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9828
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9829
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9830
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9831
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9832
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9833
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9834
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9835
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9836
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9837
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9838
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9839
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9840
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9841
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9842
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9843
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9844
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9845
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9846
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9847
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9848
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9849
	}/*function_lword_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9850
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9851
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9852
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9853
 *LWORD_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9854
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9855
	case function_lword_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9856
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9857
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9858
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9859
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9860
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9861
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9862
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9863
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9864
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9865
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9866
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9867
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9868
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9869
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9870
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9871
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9872
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9873
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9874
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9875
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9876
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9877
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9878
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9879
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9880
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9881
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9882
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9883
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9884
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9885
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9886
	}/*function_lword_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9887
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9888
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9889
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9890
 *LWORD_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9891
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9892
	case function_lword_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9893
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9894
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9895
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9896
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9897
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9898
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9899
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9900
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9901
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9902
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9903
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9904
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9905
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9906
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9907
			if (typeid(*last_type_symbol) == typeid(lword_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9908
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9909
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9910
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9911
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9912
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9913
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9914
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9915
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9916
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9917
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9918
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9919
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9920
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9921
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9922
	}/*function_lword_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9923
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9924
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9925
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9926
 *UINT_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9927
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9928
	case function_uint_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9929
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9930
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9931
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9932
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9933
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9934
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9935
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9936
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9937
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9938
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9939
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9940
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9941
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9942
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9943
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9944
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9945
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9946
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9947
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9948
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9949
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9950
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9951
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9952
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9953
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9954
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9955
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9956
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9957
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9958
	}/*function_uint_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9959
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9960
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9961
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9962
 *UINT_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9963
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9964
	case function_uint_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9965
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9966
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9967
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9968
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9969
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9970
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9971
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9972
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9973
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9974
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9975
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9976
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9977
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9978
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9979
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9980
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9981
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9982
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9983
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9984
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9985
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9986
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9987
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9988
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9989
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9990
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9991
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9992
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9993
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9994
	}/*function_uint_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9995
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9996
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9997
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9998
 *UINT_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
  9999
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10000
	case function_uint_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10001
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10002
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10003
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10004
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10005
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10006
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10007
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10008
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10009
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10010
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10011
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10012
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10013
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10014
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10015
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10016
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10017
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10018
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10019
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10020
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10021
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10022
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10023
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10024
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10025
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10026
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10027
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10028
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10029
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10030
	}/*function_uint_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10031
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10032
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10033
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10034
 *UINT_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10035
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10036
	case function_uint_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10037
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10038
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10039
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10040
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10041
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10042
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10043
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10044
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10045
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10046
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10047
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10048
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10049
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10050
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10051
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10052
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10053
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10054
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10055
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10056
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10057
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10058
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10059
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10060
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10061
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10062
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10063
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10064
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10065
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10066
	}/*function_uint_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10067
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10068
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10069
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10070
 *UINT_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10071
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10072
	case function_uint_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10073
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10074
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10075
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10076
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10077
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10078
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10079
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10080
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10081
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10082
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10083
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10084
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10085
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10086
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10087
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10088
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10089
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10090
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10091
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10092
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10093
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10094
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10095
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10096
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10097
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10098
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10099
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10100
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10101
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10102
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10103
	}/*function_uint_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10104
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10105
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10106
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10107
 *UINT_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10108
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10109
	case function_uint_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10110
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10111
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10112
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10113
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10114
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10115
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10116
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10117
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10118
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10119
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10120
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10121
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10122
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10123
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10124
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10125
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10126
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10127
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10128
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10129
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10130
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10131
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10132
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10133
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10134
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10135
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10136
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10137
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10138
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10139
	}/*function_uint_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10140
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10141
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10142
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10143
 *UINT_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10144
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10145
	case function_uint_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10146
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10147
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10148
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10149
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10150
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10151
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10152
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10153
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10154
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10155
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10156
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10157
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10158
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10159
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10160
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10161
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10162
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10163
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10164
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10165
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10166
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10167
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10168
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10169
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10170
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10171
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10172
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10173
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10174
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10175
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10176
	}/*function_uint_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10177
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10178
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10179
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10180
 *UINT_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10181
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10182
	case function_uint_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10183
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10184
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10185
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10186
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10187
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10188
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10189
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10190
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10191
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10192
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10193
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10194
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10195
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10196
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10197
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10198
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10199
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10200
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10201
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10202
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10203
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10204
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10205
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10206
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10207
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10208
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10209
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10210
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10211
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10212
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10213
	}/*function_uint_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10214
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10215
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10216
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10217
 *UINT_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10218
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10219
	case function_uint_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10220
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10221
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10222
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10223
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10224
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10225
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10226
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10227
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10228
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10229
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10230
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10231
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10232
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10233
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10234
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10235
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10236
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10237
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10238
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10239
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10240
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10241
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10242
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10243
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10244
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10245
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10246
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10247
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10248
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10249
	}/*function_uint_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10250
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10251
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10252
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10253
 *UINT_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10254
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10255
	case function_uint_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10256
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10257
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10258
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10259
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10260
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10261
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10262
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10263
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10264
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10265
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10266
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10267
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10268
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10269
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10270
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10271
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10272
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10273
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10274
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10275
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10276
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10277
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10278
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10279
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10280
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10281
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10282
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10283
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10284
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10285
	}/*function_uint_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10286
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10287
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10288
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10289
 *UINT_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10290
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10291
	case function_uint_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10292
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10293
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10294
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10295
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10296
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10297
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10298
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10299
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10300
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10301
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10302
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10303
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10304
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10305
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10306
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10307
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10308
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10309
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10310
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10311
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10312
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10313
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10314
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10315
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10316
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10317
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10318
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10319
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10320
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10321
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10322
	}/*function_uint_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10323
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10324
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10325
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10326
 *UINT_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10327
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10328
	case function_uint_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10329
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10330
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10331
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10332
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10333
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10334
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10335
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10336
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10337
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10338
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10339
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10340
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10341
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10342
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10343
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10344
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10345
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10346
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10347
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10348
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10349
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10350
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10351
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10352
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10353
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10354
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10355
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10356
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10357
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10358
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10359
	}/*function_uint_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10360
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10361
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10362
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10363
 *UINT_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10364
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10365
	case function_uint_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10366
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10367
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10368
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10369
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10370
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10371
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10372
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10373
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10374
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10375
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10376
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10377
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10378
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10379
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10380
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10381
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10382
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10383
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10384
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10385
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10386
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10387
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10388
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10389
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10390
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10391
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10392
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10393
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10394
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10395
	}/*function_uint_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10396
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10397
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10398
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10399
 *UINT_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10400
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10401
	case function_uint_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10402
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10403
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10404
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10405
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10406
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10407
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10408
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10409
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10410
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10411
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10412
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10413
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10414
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10415
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10416
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10417
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10418
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10419
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10420
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10421
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10422
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10423
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10424
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10425
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10426
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10427
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10428
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10429
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10430
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10431
	}/*function_uint_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10432
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10433
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10434
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10435
 *UINT_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10436
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10437
	case function_uint_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10438
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10439
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10440
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10441
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10442
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10443
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10444
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10445
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10446
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10447
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10448
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10449
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10450
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10451
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10452
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10453
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10454
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10455
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10456
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10457
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10458
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10459
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10460
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10461
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10462
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10463
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10464
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10465
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10466
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10467
	}/*function_uint_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10468
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10469
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10470
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10471
 *UINT_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10472
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10473
	case function_uint_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10474
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10475
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10476
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10477
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10478
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10479
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10480
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10481
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10482
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10483
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10484
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10485
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10486
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10487
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10488
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10489
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10490
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10491
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10492
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10493
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10494
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10495
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10496
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10497
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10498
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10499
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10500
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10501
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10502
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10503
	}/*function_uint_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10504
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10505
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10506
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10507
 *UINT_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10508
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10509
	case function_uint_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10510
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10511
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10512
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10513
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10514
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10515
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10516
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10517
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10518
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10519
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10520
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10521
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10522
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10523
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10524
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10525
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10526
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10527
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10528
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10529
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10530
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10531
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10532
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10533
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10534
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10535
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10536
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10537
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10538
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10539
	}/*function_uint_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10540
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10541
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10542
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10543
 *UINT_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10544
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10545
	case function_uint_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10546
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10547
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10548
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10549
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10550
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10551
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10552
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10553
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10554
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10555
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10556
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10557
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10558
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10559
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10560
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10561
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10562
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10563
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10564
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10565
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10566
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10567
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10568
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10569
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10570
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10571
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10572
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10573
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10574
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10575
	}/*function_uint_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10576
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10577
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10578
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10579
 *UINT_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10580
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10581
	case function_uint_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10582
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10583
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10584
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10585
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10586
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10587
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10588
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10589
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10590
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10591
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10592
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10593
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10594
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10595
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10596
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10597
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10598
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10599
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10600
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10601
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10602
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10603
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10604
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10605
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10606
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10607
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10608
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10609
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10610
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10611
	}/*function_uint_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10612
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10613
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10614
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10615
 *UINT_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10616
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10617
	case function_uint_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10618
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10619
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10620
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10621
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10622
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10623
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10624
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10625
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10626
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10627
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10628
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10629
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10630
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10631
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10632
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10633
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10634
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10635
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10636
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10637
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10638
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10639
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10640
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10641
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10642
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10643
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10644
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10645
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10646
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10647
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10648
	}/*function_uint_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10649
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10650
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10651
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10652
 *UINT_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10653
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10654
	case function_uint_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10655
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10656
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10657
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10658
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10659
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10660
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10661
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10662
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10663
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10664
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10665
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10666
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10667
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10668
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10669
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10670
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10671
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10672
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10673
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10674
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10675
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10676
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10677
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10678
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10679
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10680
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10681
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10682
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10683
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10684
	}/*function_uint_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10685
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10686
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10687
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10688
 *LREAL_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10689
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10690
	case function_lreal_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10691
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10692
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10693
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10694
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10695
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10696
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10697
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10698
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10699
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10700
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10701
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10702
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10703
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10704
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10705
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10706
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10707
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10708
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10709
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10710
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10711
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10712
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10713
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10714
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10715
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10716
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10717
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10718
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10719
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10720
	}/*function_lreal_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10721
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10722
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10723
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10724
 *LREAL_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10725
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10726
	case function_lreal_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10727
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10728
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10729
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10730
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10731
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10732
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10733
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10734
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10735
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10736
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10737
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10738
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10739
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10740
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10741
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10742
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10743
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10744
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10745
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10746
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10747
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10748
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10749
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10750
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10751
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10752
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10753
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10754
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10755
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10756
	}/*function_lreal_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10757
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10758
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10759
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10760
 *LREAL_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10761
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10762
	case function_lreal_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10763
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10764
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10765
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10766
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10767
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10768
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10769
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10770
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10771
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10772
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10773
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10774
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10775
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10776
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10777
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10778
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10779
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10780
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10781
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10782
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10783
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10784
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10785
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10786
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10787
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10788
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10789
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10790
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10791
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10792
	}/*function_lreal_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10793
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10794
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10795
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10796
 *LREAL_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10797
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10798
	case function_lreal_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10799
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10800
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10801
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10802
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10803
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10804
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10805
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10806
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10807
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10808
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10809
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10810
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10811
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10812
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10813
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10814
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10815
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10816
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10817
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10818
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10819
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10820
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10821
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10822
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10823
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10824
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10825
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10826
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10827
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10828
	}/*function_lreal_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10829
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10830
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10831
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10832
 *LREAL_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10833
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10834
	case function_lreal_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10835
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10836
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10837
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10838
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10839
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10840
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10841
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10842
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10843
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10844
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10845
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10846
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10847
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10848
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10849
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10850
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10851
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10852
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10853
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10854
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10855
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10856
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10857
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10858
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10859
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10860
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10861
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10862
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10863
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10864
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10865
	}/*function_lreal_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10866
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10867
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10868
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10869
 *LREAL_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10870
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10871
	case function_lreal_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10872
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10873
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10874
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10875
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10876
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10877
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10878
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10879
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10880
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10881
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10882
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10883
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10884
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10885
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10886
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10887
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10888
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10889
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10890
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10891
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10892
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10893
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10894
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10895
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10896
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10897
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10898
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10899
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10900
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10901
	}/*function_lreal_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10902
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10903
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10904
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10905
 *LREAL_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10906
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10907
	case function_lreal_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10908
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10909
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10910
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10911
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10912
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10913
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10914
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10915
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10916
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10917
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10918
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10919
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10920
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10921
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10922
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10923
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10924
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10925
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10926
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10927
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10928
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10929
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10930
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10931
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10932
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10933
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10934
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10935
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10936
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10937
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10938
	}/*function_lreal_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10939
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10940
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10941
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10942
 *LREAL_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10943
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10944
	case function_lreal_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10945
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10946
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10947
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10948
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10949
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10950
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10951
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10952
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10953
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10954
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10955
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10956
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10957
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10958
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10959
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10960
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10961
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10962
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10963
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10964
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10965
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10966
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10967
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10968
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10969
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10970
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10971
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10972
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10973
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10974
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10975
	}/*function_lreal_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10976
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10977
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10978
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10979
 *LREAL_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10980
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10981
	case function_lreal_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10982
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10983
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10984
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10985
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10986
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10987
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10988
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10989
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10990
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10991
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10992
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10993
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10994
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10995
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10996
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10997
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10998
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 10999
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11000
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11001
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11002
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11003
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11004
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11005
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11006
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11007
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11008
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11009
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11010
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11011
	}/*function_lreal_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11012
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11013
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11014
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11015
 *LREAL_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11016
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11017
	case function_lreal_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11018
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11019
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11020
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11021
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11022
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11023
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11024
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11025
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11026
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11027
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11028
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11029
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11030
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11031
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11032
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11033
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11034
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11035
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11036
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11037
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11038
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11039
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11040
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11041
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11042
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11043
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11044
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11045
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11046
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11047
	}/*function_lreal_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11048
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11049
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11050
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11051
 *LREAL_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11052
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11053
	case function_lreal_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11054
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11055
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11056
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11057
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11058
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11059
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11060
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11061
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11062
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11063
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11064
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11065
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11066
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11067
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11068
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11069
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11070
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11071
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11072
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11073
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11074
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11075
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11076
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11077
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11078
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11079
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11080
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11081
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11082
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11083
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11084
	}/*function_lreal_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11085
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11086
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11087
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11088
 *LREAL_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11089
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11090
	case function_lreal_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11091
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11092
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11093
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11094
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11095
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11096
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11097
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11098
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11099
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11100
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11101
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11102
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11103
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11104
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11105
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11106
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11107
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11108
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11109
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11110
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11111
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11112
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11113
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11114
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11115
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11116
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11117
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11118
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11119
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11120
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11121
	}/*function_lreal_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11122
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11123
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11124
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11125
 *LREAL_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11126
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11127
	case function_lreal_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11128
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11129
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11130
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11131
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11132
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11133
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11134
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11135
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11136
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11137
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11138
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11139
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11140
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11141
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11142
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11143
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11144
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11145
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11146
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11147
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11148
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11149
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11150
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11151
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11152
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11153
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11154
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11155
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11156
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11157
	}/*function_lreal_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11158
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11159
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11160
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11161
 *LREAL_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11162
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11163
	case function_lreal_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11164
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11165
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11166
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11167
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11168
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11169
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11170
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11171
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11172
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11173
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11174
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11175
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11176
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11177
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11178
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11179
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11180
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11181
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11182
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11183
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11184
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11185
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11186
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11187
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11188
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11189
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11190
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11191
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11192
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11193
	}/*function_lreal_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11194
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11195
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11196
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11197
 *LREAL_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11198
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11199
	case function_lreal_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11200
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11201
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11202
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11203
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11204
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11205
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11206
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11207
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11208
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11209
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11210
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11211
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11212
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11213
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11214
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11215
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11216
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11217
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11218
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11219
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11220
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11221
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11222
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11223
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11224
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11225
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11226
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11227
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11228
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11229
	}/*function_lreal_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11230
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11231
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11232
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11233
 *LREAL_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11234
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11235
	case function_lreal_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11236
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11237
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11238
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11239
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11240
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11241
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11242
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11243
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11244
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11245
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11246
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11247
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11248
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11249
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11250
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11251
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11252
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11253
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11254
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11255
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11256
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11257
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11258
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11259
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11260
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11261
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11262
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11263
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11264
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11265
	}/*function_lreal_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11266
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11267
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11268
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11269
 *LREAL_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11270
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11271
	case function_lreal_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11272
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11273
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11274
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11275
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11276
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11277
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11278
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11279
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11280
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11281
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11282
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11283
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11284
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11285
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11286
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11287
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11288
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11289
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11290
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11291
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11292
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11293
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11294
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11295
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11296
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11297
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11298
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11299
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11300
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11301
	}/*function_lreal_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11302
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11303
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11304
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11305
 *LREAL_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11306
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11307
	case function_lreal_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11308
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11309
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11310
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11311
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11312
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11313
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11314
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11315
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11316
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11317
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11318
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11319
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11320
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11321
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11322
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11323
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11324
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11325
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11326
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11327
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11328
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11329
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11330
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11331
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11332
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11333
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11334
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11335
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11336
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11337
	}/*function_lreal_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11338
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11339
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11340
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11341
 *LREAL_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11342
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11343
	case function_lreal_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11344
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11345
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11346
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11347
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11348
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11349
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11350
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11351
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11352
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11353
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11354
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11355
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11356
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11357
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11358
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11359
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11360
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11361
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11362
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11363
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11364
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11365
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11366
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11367
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11368
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11369
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11370
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11371
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11372
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11373
	}/*function_lreal_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11374
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11375
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11376
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11377
 *LREAL_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11378
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11379
	case function_lreal_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11380
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11381
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11382
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11383
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11384
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11385
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11386
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11387
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11388
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11389
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11390
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11391
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11392
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11393
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11394
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11395
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11396
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11397
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11398
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11399
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11400
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11401
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11402
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11403
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11404
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11405
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11406
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11407
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11408
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11409
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11410
	}/*function_lreal_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11411
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11412
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11413
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11414
 *LREAL_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11415
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11416
	case function_lreal_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11417
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11418
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11419
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11420
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11421
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11422
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11423
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11424
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11425
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11426
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11427
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11428
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11429
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11430
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11431
			if (typeid(*last_type_symbol) == typeid(lreal_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11432
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11433
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11434
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11435
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11436
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11437
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11438
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11439
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11440
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11441
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11442
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11443
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11444
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11445
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11446
	}/*function_lreal_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11447
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11448
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11449
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11450
 *BYTE_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11451
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11452
	case function_byte_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11453
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11454
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11455
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11456
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11457
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11458
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11459
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11460
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11461
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11462
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11463
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11464
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11465
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11466
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11467
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11468
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11469
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11470
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11471
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11472
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11473
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11474
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11475
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11476
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11477
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11478
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11479
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11480
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11481
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11482
	}/*function_byte_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11483
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11484
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11485
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11486
 *BYTE_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11487
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11488
	case function_byte_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11489
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11490
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11491
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11492
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11493
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11494
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11495
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11496
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11497
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11498
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11499
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11500
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11501
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11502
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11503
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11504
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11505
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11506
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11507
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11508
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11509
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11510
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11511
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11512
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11513
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11514
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11515
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11516
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11517
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11518
	}/*function_byte_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11519
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11520
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11521
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11522
 *BYTE_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11523
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11524
	case function_byte_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11525
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11526
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11527
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11528
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11529
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11530
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11531
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11532
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11533
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11534
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11535
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11536
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11537
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11538
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11539
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11540
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11541
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11542
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11543
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11544
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11545
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11546
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11547
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11548
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11549
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11550
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11551
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11552
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11553
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11554
	}/*function_byte_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11555
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11556
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11557
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11558
 *BYTE_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11559
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11560
	case function_byte_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11561
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11562
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11563
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11564
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11565
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11566
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11567
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11568
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11569
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11570
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11571
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11572
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11573
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11574
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11575
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11576
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11577
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11578
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11579
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11580
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11581
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11582
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11583
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11584
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11585
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11586
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11587
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11588
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11589
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11590
	}/*function_byte_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11591
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11592
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11593
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11594
 *BYTE_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11595
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11596
	case function_byte_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11597
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11598
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11599
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11600
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11601
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11602
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11603
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11604
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11605
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11606
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11607
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11608
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11609
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11610
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11611
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11612
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11613
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11614
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11615
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11616
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11617
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11618
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11619
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11620
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11621
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11622
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11623
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11624
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11625
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11626
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11627
	}/*function_byte_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11628
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11629
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11630
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11631
 *BYTE_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11632
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11633
	case function_byte_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11634
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11635
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11636
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11637
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11638
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11639
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11640
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11641
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11642
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11643
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11644
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11645
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11646
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11647
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11648
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11649
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11650
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11651
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11652
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11653
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11654
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11655
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11656
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11657
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11658
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11659
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11660
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11661
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11662
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11663
	}/*function_byte_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11664
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11665
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11666
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11667
 *BYTE_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11668
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11669
	case function_byte_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11670
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11671
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11672
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11673
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11674
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11675
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11676
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11677
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11678
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11679
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11680
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11681
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11682
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11683
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11684
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11685
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11686
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11687
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11688
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11689
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11690
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11691
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11692
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11693
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11694
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11695
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11696
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11697
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11698
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11699
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11700
	}/*function_byte_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11701
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11702
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11703
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11704
 *BYTE_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11705
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11706
	case function_byte_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11707
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11708
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11709
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11710
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11711
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11712
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11713
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11714
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11715
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11716
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11717
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11718
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11719
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11720
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11721
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11722
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11723
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11724
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11725
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11726
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11727
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11728
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11729
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11730
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11731
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11732
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11733
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11734
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11735
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11736
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11737
	}/*function_byte_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11738
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11739
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11740
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11741
 *BYTE_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11742
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11743
	case function_byte_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11744
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11745
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11746
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11747
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11748
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11749
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11750
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11751
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11752
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11753
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11754
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11755
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11756
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11757
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11758
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11759
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11760
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11761
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11762
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11763
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11764
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11765
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11766
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11767
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11768
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11769
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11770
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11771
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11772
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11773
	}/*function_byte_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11774
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11775
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11776
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11777
 *BYTE_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11778
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11779
	case function_byte_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11780
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11781
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11782
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11783
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11784
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11785
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11786
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11787
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11788
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11789
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11790
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11791
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11792
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11793
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11794
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11795
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11796
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11797
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11798
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11799
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11800
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11801
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11802
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11803
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11804
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11805
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11806
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11807
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11808
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11809
	}/*function_byte_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11810
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11811
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11812
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11813
 *BYTE_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11814
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11815
	case function_byte_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11816
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11817
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11818
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11819
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11820
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11821
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11822
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11823
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11824
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11825
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11826
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11827
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11828
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11829
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11830
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11831
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11832
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11833
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11834
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11835
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11836
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11837
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11838
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11839
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11840
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11841
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11842
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11843
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11844
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11845
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11846
	}/*function_byte_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11847
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11848
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11849
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11850
 *BYTE_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11851
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11852
	case function_byte_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11853
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11854
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11855
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11856
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11857
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11858
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11859
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11860
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11861
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11862
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11863
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11864
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11865
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11866
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11867
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11868
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11869
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11870
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11871
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11872
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11873
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11874
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11875
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11876
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11877
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11878
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11879
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11880
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11881
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11882
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11883
	}/*function_byte_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11884
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11885
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11886
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11887
 *BYTE_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11888
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11889
	case function_byte_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11890
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11891
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11892
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11893
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11894
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11895
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11896
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11897
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11898
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11899
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11900
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11901
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11902
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11903
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11904
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11905
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11906
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11907
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11908
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11909
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11910
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11911
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11912
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11913
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11914
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11915
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11916
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11917
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11918
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11919
	}/*function_byte_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11920
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11921
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11922
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11923
 *BYTE_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11924
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11925
	case function_byte_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11926
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11927
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11928
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11929
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11930
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11931
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11932
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11933
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11934
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11935
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11936
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11937
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11938
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11939
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11940
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11941
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11942
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11943
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11944
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11945
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11946
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11947
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11948
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11949
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11950
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11951
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11952
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11953
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11954
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11955
	}/*function_byte_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11956
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11957
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11958
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11959
 *BYTE_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11960
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11961
	case function_byte_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11962
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11963
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11964
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11965
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11966
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11967
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11968
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11969
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11970
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11971
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11972
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11973
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11974
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11975
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11976
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11977
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11978
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11979
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11980
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11981
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11982
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11983
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11984
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11985
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11986
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11987
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11988
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11989
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11990
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11991
	}/*function_byte_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11992
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11993
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11994
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11995
 *BYTE_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11996
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11997
	case function_byte_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11998
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 11999
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12000
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12001
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12002
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12003
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12004
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12005
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12006
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12007
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12008
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12009
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12010
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12011
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12012
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12013
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12014
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12015
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12016
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12017
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12018
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12019
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12020
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12021
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12022
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12023
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12024
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12025
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12026
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12027
	}/*function_byte_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12028
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12029
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12030
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12031
 *BYTE_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12032
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12033
	case function_byte_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12034
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12035
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12036
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12037
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12038
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12039
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12040
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12041
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12042
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12043
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12044
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12045
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12046
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12047
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12048
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12049
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12050
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12051
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12052
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12053
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12054
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12055
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12056
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12057
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12058
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12059
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12060
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12061
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12062
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12063
	}/*function_byte_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12064
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12065
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12066
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12067
 *BYTE_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12068
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12069
	case function_byte_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12070
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12071
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12072
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12073
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12074
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12075
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12076
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12077
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12078
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12079
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12080
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12081
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12082
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12083
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12084
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12085
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12086
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12087
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12088
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12089
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12090
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12091
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12092
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12093
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12094
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12095
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12096
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12097
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12098
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12099
	}/*function_byte_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12100
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12101
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12102
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12103
 *BYTE_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12104
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12105
	case function_byte_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12106
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12107
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12108
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12109
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12110
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12111
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12112
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12113
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12114
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12115
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12116
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12117
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12118
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12119
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12120
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12121
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12122
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12123
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12124
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12125
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12126
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12127
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12128
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12129
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12130
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12131
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12132
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12133
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12134
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12135
	}/*function_byte_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12136
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12137
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12138
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12139
 *BYTE_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12140
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12141
	case function_byte_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12142
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12143
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12144
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12145
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12146
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12147
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12148
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12149
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12150
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12151
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12152
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12153
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12154
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12155
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12156
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12157
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12158
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12159
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12160
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12161
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12162
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12163
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12164
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12165
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12166
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12167
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12168
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12169
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12170
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12171
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12172
	}/*function_byte_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12173
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12174
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12175
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12176
 *BYTE_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12177
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12178
	case function_byte_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12179
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12180
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12181
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12182
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12183
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12184
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12185
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12186
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12187
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12188
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12189
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12190
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12191
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12192
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12193
			if (typeid(*last_type_symbol) == typeid(byte_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12194
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12195
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12196
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12197
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12198
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12199
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12200
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12201
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12202
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12203
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12204
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12205
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12206
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12207
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12208
	}/*function_byte_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12209
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12210
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12211
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12212
 *USINT_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12213
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12214
	case function_usint_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12215
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12216
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12217
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12218
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12219
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12220
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12221
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12222
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12223
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12224
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12225
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12226
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12227
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12228
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12229
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12230
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12231
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12232
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12233
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12234
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12235
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12236
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12237
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12238
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12239
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12240
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12241
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12242
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12243
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12244
	}/*function_usint_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12245
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12246
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12247
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12248
 *USINT_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12249
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12250
	case function_usint_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12251
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12252
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12253
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12254
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12255
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12256
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12257
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12258
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12259
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12260
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12261
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12262
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12263
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12264
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12265
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12266
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12267
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12268
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12269
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12270
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12271
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12272
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12273
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12274
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12275
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12276
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12277
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12278
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12279
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12280
	}/*function_usint_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12281
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12282
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12283
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12284
 *USINT_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12285
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12286
	case function_usint_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12287
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12288
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12289
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12290
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12291
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12292
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12293
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12294
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12295
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12296
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12297
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12298
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12299
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12300
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12301
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12302
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12303
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12304
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12305
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12306
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12307
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12308
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12309
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12310
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12311
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12312
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12313
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12314
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12315
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12316
	}/*function_usint_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12317
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12318
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12319
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12320
 *USINT_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12321
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12322
	case function_usint_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12323
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12324
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12325
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12326
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12327
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12328
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12329
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12330
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12331
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12332
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12333
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12334
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12335
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12336
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12337
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12338
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12339
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12340
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12341
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12342
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12343
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12344
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12345
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12346
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12347
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12348
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12349
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12350
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12351
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12352
	}/*function_usint_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12353
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12354
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12355
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12356
 *USINT_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12357
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12358
	case function_usint_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12359
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12360
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12361
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12362
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12363
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12364
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12365
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12366
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12367
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12368
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12369
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12370
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12371
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12372
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12373
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12374
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12375
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12376
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12377
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12378
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12379
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12380
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12381
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12382
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12383
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12384
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12385
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12386
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12387
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12388
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12389
	}/*function_usint_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12390
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12391
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12392
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12393
 *USINT_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12394
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12395
	case function_usint_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12396
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12397
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12398
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12399
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12400
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12401
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12402
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12403
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12404
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12405
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12406
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12407
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12408
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12409
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12410
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12411
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12412
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12413
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12414
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12415
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12416
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12417
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12418
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12419
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12420
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12421
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12422
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12423
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12424
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12425
	}/*function_usint_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12426
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12427
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12428
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12429
 *USINT_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12430
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12431
	case function_usint_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12432
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12433
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12434
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12435
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12436
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12437
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12438
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12439
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12440
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12441
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12442
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12443
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12444
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12445
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12446
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12447
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12448
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12449
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12450
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12451
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12452
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12453
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12454
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12455
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12456
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12457
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12458
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12459
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12460
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12461
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12462
	}/*function_usint_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12463
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12464
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12465
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12466
 *USINT_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12467
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12468
	case function_usint_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12469
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12470
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12471
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12472
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12473
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12474
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12475
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12476
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12477
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12478
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12479
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12480
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12481
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12482
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12483
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12484
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12485
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12486
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12487
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12488
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12489
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12490
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12491
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12492
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12493
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12494
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12495
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12496
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12497
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12498
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12499
	}/*function_usint_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12500
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12501
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12502
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12503
 *USINT_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12504
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12505
	case function_usint_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12506
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12507
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12508
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12509
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12510
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12511
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12512
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12513
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12514
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12515
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12516
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12517
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12518
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12519
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12520
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12521
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12522
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12523
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12524
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12525
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12526
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12527
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12528
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12529
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12530
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12531
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12532
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12533
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12534
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12535
	}/*function_usint_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12536
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12537
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12538
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12539
 *USINT_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12540
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12541
	case function_usint_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12542
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12543
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12544
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12545
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12546
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12547
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12548
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12549
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12550
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12551
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12552
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12553
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12554
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12555
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12556
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12557
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12558
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12559
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12560
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12561
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12562
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12563
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12564
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12565
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12566
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12567
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12568
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12569
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12570
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12571
	}/*function_usint_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12572
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12573
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12574
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12575
 *USINT_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12576
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12577
	case function_usint_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12578
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12579
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12580
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12581
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12582
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12583
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12584
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12585
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12586
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12587
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12588
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12589
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12590
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12591
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12592
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12593
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12594
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12595
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12596
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12597
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12598
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12599
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12600
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12601
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12602
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12603
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12604
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12605
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12606
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12607
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12608
	}/*function_usint_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12609
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12610
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12611
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12612
 *USINT_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12613
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12614
	case function_usint_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12615
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12616
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12617
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12618
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12619
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12620
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12621
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12622
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12623
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12624
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12625
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12626
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12627
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12628
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12629
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12630
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12631
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12632
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12633
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12634
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12635
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12636
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12637
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12638
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12639
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12640
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12641
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12642
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12643
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12644
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12645
	}/*function_usint_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12646
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12647
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12648
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12649
 *USINT_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12650
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12651
	case function_usint_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12652
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12653
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12654
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12655
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12656
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12657
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12658
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12659
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12660
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12661
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12662
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12663
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12664
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12665
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12666
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12667
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12668
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12669
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12670
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12671
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12672
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12673
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12674
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12675
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12676
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12677
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12678
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12679
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12680
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12681
	}/*function_usint_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12682
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12683
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12684
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12685
 *USINT_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12686
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12687
	case function_usint_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12688
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12689
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12690
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12691
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12692
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12693
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12694
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12695
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12696
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12697
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12698
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12699
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12700
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12701
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12702
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12703
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12704
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12705
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12706
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12707
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12708
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12709
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12710
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12711
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12712
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12713
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12714
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12715
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12716
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12717
	}/*function_usint_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12718
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12719
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12720
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12721
 *USINT_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12722
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12723
	case function_usint_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12724
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12725
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12726
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12727
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12728
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12729
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12730
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12731
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12732
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12733
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12734
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12735
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12736
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12737
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12738
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12739
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12740
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12741
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12742
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12743
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12744
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12745
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12746
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12747
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12748
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12749
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12750
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12751
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12752
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12753
	}/*function_usint_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12754
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12755
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12756
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12757
 *USINT_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12758
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12759
	case function_usint_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12760
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12761
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12762
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12763
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12764
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12765
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12766
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12767
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12768
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12769
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12770
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12771
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12772
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12773
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12774
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12775
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12776
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12777
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12778
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12779
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12780
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12781
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12782
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12783
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12784
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12785
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12786
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12787
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12788
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12789
	}/*function_usint_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12790
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12791
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12792
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12793
 *USINT_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12794
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12795
	case function_usint_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12796
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12797
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12798
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12799
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12800
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12801
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12802
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12803
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12804
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12805
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12806
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12807
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12808
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12809
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12810
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12811
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12812
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12813
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12814
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12815
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12816
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12817
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12818
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12819
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12820
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12821
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12822
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12823
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12824
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12825
	}/*function_usint_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12826
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12827
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12828
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12829
 *USINT_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12830
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12831
	case function_usint_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12832
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12833
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12834
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12835
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12836
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12837
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12838
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12839
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12840
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12841
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12842
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12843
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12844
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12845
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12846
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12847
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12848
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12849
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12850
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12851
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12852
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12853
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12854
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12855
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12856
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12857
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12858
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12859
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12860
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12861
	}/*function_usint_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12862
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12863
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12864
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12865
 *USINT_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12866
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12867
	case function_usint_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12868
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12869
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12870
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12871
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12872
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12873
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12874
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12875
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12876
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12877
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12878
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12879
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12880
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12881
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12882
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12883
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12884
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12885
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12886
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12887
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12888
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12889
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12890
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12891
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12892
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12893
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12894
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12895
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12896
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12897
	}/*function_usint_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12898
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12899
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12900
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12901
 *USINT_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12902
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12903
	case function_usint_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12904
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12905
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12906
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12907
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12908
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12909
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12910
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12911
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12912
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12913
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12914
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12915
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12916
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12917
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12918
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12919
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12920
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12921
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12922
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12923
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12924
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12925
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12926
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12927
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12928
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12929
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12930
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12931
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12932
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12933
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12934
	}/*function_usint_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12935
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12936
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12937
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12938
 *USINT_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12939
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12940
	case function_usint_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12941
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12942
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12943
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12944
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12945
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12946
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12947
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12948
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12949
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12950
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12951
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12952
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12953
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12954
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12955
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12956
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12957
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12958
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12959
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12960
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12961
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12962
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12963
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12964
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12965
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12966
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12967
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12968
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12969
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12970
	}/*function_usint_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12971
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12972
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12973
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12974
 *ULINT_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12975
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12976
	case function_ulint_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12977
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12978
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12979
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12980
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12981
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12982
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12983
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12984
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12985
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12986
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12987
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12988
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12989
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12990
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12991
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12992
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12993
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12994
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12995
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12996
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12997
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12998
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 12999
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13000
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13001
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13002
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13003
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13004
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13005
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13006
	}/*function_ulint_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13007
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13008
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13009
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13010
 *ULINT_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13011
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13012
	case function_ulint_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13013
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13014
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13015
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13016
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13017
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13018
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13019
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13020
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13021
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13022
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13023
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13024
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13025
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13026
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13027
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13028
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13029
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13030
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13031
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13032
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13033
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13034
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13035
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13036
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13037
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13038
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13039
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13040
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13041
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13042
	}/*function_ulint_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13043
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13044
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13045
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13046
 *ULINT_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13047
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13048
	case function_ulint_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13049
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13050
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13051
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13052
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13053
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13054
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13055
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13056
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13057
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13058
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13059
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13060
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13061
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13062
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13063
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13064
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13065
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13066
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13067
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13068
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13069
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13070
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13071
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13072
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13073
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13074
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13075
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13076
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13077
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13078
	}/*function_ulint_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13079
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13080
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13081
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13082
 *ULINT_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13083
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13084
	case function_ulint_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13085
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13086
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13087
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13088
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13089
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13090
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13091
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13092
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13093
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13094
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13095
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13096
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13097
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13098
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13099
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13100
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13101
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13102
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13103
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13104
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13105
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13106
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13107
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13108
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13109
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13110
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13111
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13112
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13113
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13114
	}/*function_ulint_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13115
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13116
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13117
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13118
 *ULINT_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13119
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13120
	case function_ulint_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13121
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13122
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13123
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13124
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13125
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13126
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13127
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13128
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13129
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13130
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13131
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13132
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13133
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13134
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13135
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13136
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13137
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13138
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13139
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13140
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13141
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13142
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13143
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13144
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13145
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13146
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13147
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13148
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13149
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13150
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13151
	}/*function_ulint_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13152
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13153
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13154
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13155
 *ULINT_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13156
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13157
	case function_ulint_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13158
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13159
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13160
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13161
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13162
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13163
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13164
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13165
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13166
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13167
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13168
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13169
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13170
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13171
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13172
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13173
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13174
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13175
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13176
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13177
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13178
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13179
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13180
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13181
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13182
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13183
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13184
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13185
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13186
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13187
	}/*function_ulint_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13188
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13189
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13190
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13191
 *ULINT_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13192
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13193
	case function_ulint_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13194
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13195
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13196
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13197
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13198
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13199
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13200
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13201
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13202
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13203
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13204
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13205
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13206
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13207
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13208
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13209
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13210
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13211
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13212
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13213
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13214
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13215
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13216
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13217
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13218
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13219
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13220
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13221
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13222
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13223
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13224
	}/*function_ulint_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13225
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13226
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13227
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13228
 *ULINT_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13229
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13230
	case function_ulint_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13231
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13232
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13233
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13234
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13235
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13236
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13237
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13238
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13239
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13240
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13241
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13242
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13243
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13244
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13245
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13246
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13247
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13248
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13249
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13250
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13251
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13252
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13253
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13254
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13255
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13256
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13257
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13258
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13259
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13260
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13261
	}/*function_ulint_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13262
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13263
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13264
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13265
 *ULINT_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13266
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13267
	case function_ulint_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13268
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13269
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13270
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13271
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13272
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13273
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13274
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13275
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13276
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13277
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13278
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13279
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13280
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13281
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13282
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13283
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13284
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13285
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13286
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13287
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13288
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13289
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13290
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13291
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13292
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13293
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13294
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13295
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13296
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13297
	}/*function_ulint_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13298
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13299
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13300
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13301
 *ULINT_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13302
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13303
	case function_ulint_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13304
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13305
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13306
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13307
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13308
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13309
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13310
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13311
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13312
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13313
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13314
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13315
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13316
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13317
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13318
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13319
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13320
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13321
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13322
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13323
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13324
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13325
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13326
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13327
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13328
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13329
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13330
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13331
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13332
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13333
	}/*function_ulint_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13334
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13335
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13336
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13337
 *ULINT_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13338
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13339
	case function_ulint_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13340
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13341
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13342
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13343
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13344
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13345
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13346
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13347
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13348
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13349
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13350
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13351
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13352
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13353
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13354
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13355
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13356
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13357
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13358
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13359
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13360
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13361
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13362
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13363
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13364
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13365
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13366
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13367
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13368
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13369
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13370
	}/*function_ulint_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13371
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13372
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13373
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13374
 *ULINT_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13375
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13376
	case function_ulint_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13377
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13378
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13379
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13380
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13381
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13382
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13383
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13384
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13385
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13386
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13387
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13388
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13389
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13390
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13391
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13392
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13393
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13394
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13395
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13396
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13397
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13398
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13399
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13400
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13401
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13402
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13403
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13404
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13405
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13406
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13407
	}/*function_ulint_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13408
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13409
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13410
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13411
 *ULINT_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13412
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13413
	case function_ulint_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13414
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13415
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13416
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13417
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13418
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13419
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13420
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13421
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13422
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13423
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13424
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13425
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13426
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13427
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13428
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13429
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13430
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13431
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13432
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13433
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13434
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13435
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13436
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13437
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13438
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13439
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13440
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13441
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13442
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13443
	}/*function_ulint_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13444
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13445
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13446
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13447
 *ULINT_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13448
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13449
	case function_ulint_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13450
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13451
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13452
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13453
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13454
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13455
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13456
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13457
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13458
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13459
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13460
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13461
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13462
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13463
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13464
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13465
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13466
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13467
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13468
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13469
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13470
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13471
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13472
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13473
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13474
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13475
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13476
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13477
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13478
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13479
	}/*function_ulint_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13480
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13481
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13482
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13483
 *ULINT_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13484
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13485
	case function_ulint_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13486
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13487
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13488
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13489
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13490
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13491
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13492
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13493
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13494
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13495
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13496
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13497
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13498
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13499
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13500
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13501
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13502
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13503
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13504
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13505
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13506
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13507
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13508
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13509
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13510
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13511
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13512
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13513
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13514
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13515
	}/*function_ulint_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13516
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13517
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13518
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13519
 *ULINT_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13520
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13521
	case function_ulint_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13522
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13523
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13524
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13525
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13526
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13527
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13528
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13529
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13530
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13531
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13532
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13533
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13534
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13535
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13536
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13537
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13538
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13539
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13540
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13541
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13542
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13543
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13544
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13545
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13546
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13547
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13548
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13549
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13550
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13551
	}/*function_ulint_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13552
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13553
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13554
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13555
 *ULINT_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13556
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13557
	case function_ulint_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13558
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13559
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13560
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13561
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13562
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13563
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13564
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13565
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13566
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13567
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13568
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13569
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13570
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13571
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13572
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13573
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13574
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13575
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13576
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13577
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13578
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13579
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13580
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13581
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13582
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13583
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13584
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13585
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13586
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13587
	}/*function_ulint_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13588
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13589
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13590
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13591
 *ULINT_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13592
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13593
	case function_ulint_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13594
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13595
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13596
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13597
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13598
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13599
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13600
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13601
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13602
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13603
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13604
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13605
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13606
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13607
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13608
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13609
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13610
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13611
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13612
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13613
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13614
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13615
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13616
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13617
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13618
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13619
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13620
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13621
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13622
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13623
	}/*function_ulint_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13624
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13625
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13626
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13627
 *ULINT_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13628
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13629
	case function_ulint_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13630
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13631
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13632
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13633
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13634
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13635
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13636
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13637
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13638
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13639
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13640
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13641
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13642
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13643
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13644
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13645
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13646
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13647
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13648
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13649
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13650
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13651
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13652
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13653
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13654
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13655
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13656
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13657
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13658
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13659
	}/*function_ulint_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13660
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13661
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13662
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13663
 *ULINT_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13664
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13665
	case function_ulint_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13666
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13667
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13668
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13669
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13670
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13671
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13672
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13673
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13674
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13675
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13676
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13677
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13678
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13679
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13680
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13681
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13682
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13683
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13684
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13685
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13686
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13687
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13688
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13689
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13690
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13691
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13692
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13693
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13694
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13695
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13696
	}/*function_ulint_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13697
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13698
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13699
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13700
 *ULINT_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13701
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13702
	case function_ulint_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13703
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13704
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13705
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13706
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13707
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13708
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13709
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13710
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13711
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13712
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13713
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13714
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13715
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13716
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13717
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13718
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13719
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13720
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13721
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13722
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13723
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13724
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13725
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13726
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13727
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13728
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13729
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13730
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13731
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13732
	}/*function_ulint_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13733
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13734
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13735
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13736
 *BOOL_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13737
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13738
	case function_bool_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13739
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13740
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13741
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13742
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13743
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13744
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13745
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13746
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13747
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13748
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13749
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13750
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13751
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13752
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13753
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13754
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13755
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13756
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13757
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13758
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13759
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13760
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13761
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13762
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13763
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13764
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13765
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13766
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13767
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13768
	}/*function_bool_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13769
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13770
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13771
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13772
 *BOOL_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13773
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13774
	case function_bool_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13775
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13776
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13777
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13778
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13779
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13780
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13781
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13782
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13783
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13784
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13785
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13786
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13787
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13788
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13789
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13790
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13791
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13792
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13793
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13794
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13795
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13796
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13797
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13798
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13799
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13800
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13801
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13802
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13803
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13804
	}/*function_bool_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13805
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13806
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13807
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13808
 *BOOL_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13809
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13810
	case function_bool_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13811
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13812
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13813
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13814
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13815
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13816
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13817
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13818
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13819
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13820
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13821
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13822
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13823
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13824
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13825
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13826
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13827
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13828
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13829
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13830
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13831
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13832
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13833
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13834
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13835
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13836
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13837
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13838
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13839
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13840
	}/*function_bool_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13841
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13842
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13843
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13844
 *BOOL_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13845
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13846
	case function_bool_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13847
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13848
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13849
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13850
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13851
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13852
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13853
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13854
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13855
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13856
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13857
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13858
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13859
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13860
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13861
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13862
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13863
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13864
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13865
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13866
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13867
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13868
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13869
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13870
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13871
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13872
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13873
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13874
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13875
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13876
	}/*function_bool_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13877
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13878
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13879
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13880
 *BOOL_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13881
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13882
	case function_bool_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13883
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13884
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13885
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13886
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13887
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13888
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13889
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13890
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13891
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13892
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13893
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13894
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13895
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13896
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13897
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13898
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13899
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13900
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13901
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13902
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13903
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13904
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13905
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13906
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13907
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13908
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13909
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13910
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13911
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13912
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13913
	}/*function_bool_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13914
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13915
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13916
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13917
 *BOOL_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13918
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13919
	case function_bool_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13920
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13921
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13922
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13923
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13924
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13925
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13926
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13927
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13928
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13929
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13930
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13931
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13932
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13933
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13934
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13935
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13936
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13937
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13938
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13939
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13940
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13941
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13942
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13943
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13944
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13945
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13946
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13947
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13948
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13949
	}/*function_bool_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13950
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13951
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13952
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13953
 *BOOL_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13954
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13955
	case function_bool_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13956
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13957
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13958
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13959
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13960
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13961
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13962
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13963
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13964
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13965
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13966
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13967
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13968
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13969
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13970
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13971
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13972
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13973
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13974
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13975
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13976
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13977
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13978
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13979
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13980
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13981
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13982
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13983
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13984
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13985
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13986
	}/*function_bool_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13987
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13988
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13989
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13990
 *BOOL_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13991
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13992
	case function_bool_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13993
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13994
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13995
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13996
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13997
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13998
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 13999
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14000
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14001
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14002
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14003
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14004
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14005
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14006
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14007
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14008
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14009
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14010
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14011
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14012
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14013
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14014
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14015
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14016
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14017
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14018
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14019
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14020
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14021
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14022
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14023
	}/*function_bool_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14024
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14025
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14026
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14027
 *BOOL_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14028
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14029
	case function_bool_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14030
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14031
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14032
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14033
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14034
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14035
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14036
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14037
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14038
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14039
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14040
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14041
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14042
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14043
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14044
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14045
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14046
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14047
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14048
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14049
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14050
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14051
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14052
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14053
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14054
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14055
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14056
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14057
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14058
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14059
	}/*function_bool_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14060
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14061
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14062
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14063
 *BOOL_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14064
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14065
	case function_bool_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14066
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14067
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14068
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14069
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14070
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14071
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14072
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14073
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14074
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14075
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14076
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14077
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14078
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14079
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14080
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14081
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14082
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14083
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14084
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14085
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14086
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14087
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14088
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14089
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14090
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14091
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14092
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14093
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14094
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14095
	}/*function_bool_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14096
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14097
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14098
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14099
 *BOOL_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14100
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14101
	case function_bool_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14102
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14103
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14104
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14105
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14106
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14107
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14108
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14109
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14110
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14111
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14112
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14113
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14114
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14115
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14116
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14117
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14118
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14119
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14120
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14121
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14122
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14123
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14124
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14125
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14126
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14127
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14128
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14129
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14130
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14131
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14132
	}/*function_bool_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14133
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14134
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14135
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14136
 *BOOL_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14137
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14138
	case function_bool_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14139
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14140
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14141
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14142
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14143
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14144
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14145
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14146
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14147
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14148
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14149
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14150
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14151
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14152
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14153
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14154
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14155
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14156
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14157
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14158
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14159
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14160
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14161
				s4o.print(", 16)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14162
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14163
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14164
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14165
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14166
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14167
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14168
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14169
	}/*function_bool_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14170
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14171
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14172
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14173
 *BOOL_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14174
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14175
	case function_bool_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14176
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14177
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14178
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14179
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14180
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14181
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14182
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14183
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14184
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14185
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14186
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14187
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14188
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14189
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14190
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14191
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14192
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14193
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14194
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14195
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14196
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14197
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14198
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14199
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14200
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14201
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14202
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14203
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14204
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14205
	}/*function_bool_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14206
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14207
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14208
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14209
 *BOOL_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14210
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14211
	case function_bool_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14212
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14213
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14214
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14215
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14216
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14217
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14218
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14219
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14220
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14221
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14222
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14223
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14224
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14225
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14226
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14227
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14228
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14229
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14230
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14231
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14232
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14233
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14234
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14235
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14236
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14237
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14238
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14239
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14240
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14241
	}/*function_bool_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14242
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14243
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14244
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14245
 *BOOL_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14246
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14247
	case function_bool_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14248
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14249
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14250
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14251
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14252
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14253
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14254
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14255
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14256
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14257
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14258
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14259
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14260
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14261
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14262
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14263
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14264
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14265
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14266
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14267
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14268
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14269
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14270
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14271
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14272
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14273
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14274
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14275
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14276
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14277
	}/*function_bool_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14278
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14279
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14280
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14281
 *BOOL_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14282
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14283
	case function_bool_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14284
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14285
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14286
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14287
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14288
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14289
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14290
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14291
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14292
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14293
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14294
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14295
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14296
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14297
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14298
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14299
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14300
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14301
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14302
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14303
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14304
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14305
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14306
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14307
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14308
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14309
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14310
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14311
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14312
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14313
	}/*function_bool_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14314
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14315
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14316
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14317
 *BOOL_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14318
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14319
	case function_bool_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14320
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14321
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14322
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14323
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14324
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14325
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14326
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14327
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14328
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14329
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14330
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14331
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14332
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14333
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14334
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14335
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14336
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14337
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14338
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14339
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14340
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14341
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14342
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14343
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14344
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14345
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14346
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14347
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14348
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14349
	}/*function_bool_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14350
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14351
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14352
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14353
 *BOOL_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14354
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14355
	case function_bool_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14356
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14357
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14358
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14359
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14360
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14361
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14362
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14363
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14364
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14365
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14366
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14367
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14368
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14369
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14370
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14371
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14372
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14373
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14374
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14375
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14376
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14377
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14378
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14379
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14380
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14381
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14382
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14383
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14384
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14385
	}/*function_bool_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14386
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14387
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14388
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14389
 *BOOL_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14390
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14391
	case function_bool_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14392
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14393
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14394
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14395
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14396
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14397
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14398
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14399
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14400
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14401
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14402
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14403
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14404
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14405
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14406
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14407
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14408
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14409
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14410
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14411
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14412
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14413
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14414
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14415
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14416
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14417
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14418
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14419
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14420
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14421
	}/*function_bool_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14422
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14423
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14424
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14425
 *BOOL_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14426
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14427
	case function_bool_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14428
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14429
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14430
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14431
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14432
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14433
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14434
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14435
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14436
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14437
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14438
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14439
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14440
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14441
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14442
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14443
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14444
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14445
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14446
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14447
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14448
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14449
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14450
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14451
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14452
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14453
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14454
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14455
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14456
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14457
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14458
	}/*function_bool_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14459
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14460
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14461
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14462
 *BOOL_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14463
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14464
	case function_bool_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14465
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14466
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14467
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14468
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14469
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14470
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14471
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14472
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14473
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14474
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14475
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14476
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14477
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14478
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14479
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14480
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14481
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14482
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14483
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14484
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14485
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14486
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14487
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14488
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14489
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14490
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14491
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14492
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14493
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14494
	}/*function_bool_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14495
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14496
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14497
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14498
 *TIME_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14499
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14500
	case function_time_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14501
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14502
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14503
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14504
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14505
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14506
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14507
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14508
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14509
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14510
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14511
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14512
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14513
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14514
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14515
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14516
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14517
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14518
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14519
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14520
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14521
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14522
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14523
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14524
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14525
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14526
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14527
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14528
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14529
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14530
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14531
	}/*function_time_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14532
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14533
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14534
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14535
 *TIME_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14536
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14537
	case function_time_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14538
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14539
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14540
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14541
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14542
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14543
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14544
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14545
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14546
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14547
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14548
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14549
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14550
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14551
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14552
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14553
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14554
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14555
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14556
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14557
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14558
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14559
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14560
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14561
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14562
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14563
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14564
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14565
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14566
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14567
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14568
	}/*function_time_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14569
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14570
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14571
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14572
 *TIME_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14573
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14574
	case function_time_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14575
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14576
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14577
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14578
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14579
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14580
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14581
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14582
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14583
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14584
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14585
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14586
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14587
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14588
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14589
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14590
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14591
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14592
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14593
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14594
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14595
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14596
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14597
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14598
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14599
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14600
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14601
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14602
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14603
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14604
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14605
	}/*function_time_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14606
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14607
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14608
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14609
 *TIME_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14610
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14611
	case function_time_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14612
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14613
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14614
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14615
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14616
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14617
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14618
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14619
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14620
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14621
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14622
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14623
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14624
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14625
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14626
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14627
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14628
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14629
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14630
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14631
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14632
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14633
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14634
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14635
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14636
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14637
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14638
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14639
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14640
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14641
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14642
	}/*function_time_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14643
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14644
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14645
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14646
 *TIME_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14647
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14648
	case function_time_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14649
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14650
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14651
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14652
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14653
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14654
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14655
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14656
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14657
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14658
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14659
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14660
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14661
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14662
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14663
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14664
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14665
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14666
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14667
				s4o.print("#error TIME_TO_DATE not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14668
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14669
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14670
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14671
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14672
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14673
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14674
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14675
	}/*function_time_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14676
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14677
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14678
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14679
 *TIME_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14680
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14681
	case function_time_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14682
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14683
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14684
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14685
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14686
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14687
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14688
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14689
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14690
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14691
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14692
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14693
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14694
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14695
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14696
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14697
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14698
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14699
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14700
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14701
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14702
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14703
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14704
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14705
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14706
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14707
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14708
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14709
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14710
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14711
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14712
	}/*function_time_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14713
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14714
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14715
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14716
 *TIME_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14717
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14718
	case function_time_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14719
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14720
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14721
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14722
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14723
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14724
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14725
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14726
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14727
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14728
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14729
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14730
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14731
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14732
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14733
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14734
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14735
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14736
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14737
				s4o.print("#error TIME_TO_DT not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14738
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14739
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14740
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14741
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14742
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14743
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14744
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14745
	}/*function_time_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14746
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14747
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14748
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14749
 *TIME_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14750
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14751
	case function_time_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14752
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14753
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14754
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14755
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14756
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14757
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14758
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14759
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14760
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14761
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14762
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14763
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14764
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14765
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14766
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14767
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14768
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14769
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14770
				s4o.print("#error TIME_TO_TOD not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14771
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14772
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14773
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14774
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14775
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14776
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14777
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14778
	}/*function_time_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14779
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14780
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14781
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14782
 *TIME_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14783
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14784
	case function_time_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14785
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14786
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14787
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14788
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14789
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14790
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14791
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14792
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14793
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14794
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14795
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14796
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14797
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14798
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14799
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14800
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14801
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14802
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14803
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14804
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14805
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14806
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14807
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14808
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14809
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14810
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14811
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14812
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14813
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14814
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14815
	}/*function_time_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14816
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14817
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14818
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14819
 *TIME_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14820
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14821
	case function_time_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14822
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14823
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14824
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14825
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14826
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14827
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14828
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14829
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14830
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14831
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14832
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14833
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14834
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14835
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14836
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14837
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14838
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14839
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14840
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14841
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14842
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14843
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14844
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14845
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14846
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14847
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14848
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14849
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14850
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14851
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14852
	}/*function_time_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14853
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14854
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14855
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14856
 *TIME_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14857
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14858
	case function_time_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14859
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14860
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14861
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14862
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14863
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14864
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14865
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14866
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14867
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14868
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14869
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14870
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14871
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14872
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14873
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14874
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14875
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14876
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14877
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14878
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14879
				s4o.print(")string_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14880
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14881
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14882
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14883
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14884
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14885
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14886
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14887
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14888
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14889
	}/*function_time_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14890
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14891
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14892
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14893
 *TIME_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14894
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14895
	case function_time_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14896
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14897
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14898
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14899
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14900
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14901
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14902
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14903
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14904
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14905
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14906
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14907
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14908
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14909
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14910
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14911
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14912
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14913
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14914
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14915
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14916
				s4o.print(")string_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14917
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14918
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14919
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14920
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14921
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14922
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14923
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14924
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14925
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14926
	}/*function_time_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14927
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14928
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14929
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14930
 *TIME_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14931
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14932
	case function_time_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14933
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14934
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14935
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14936
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14937
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14938
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14939
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14940
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14941
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14942
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14943
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14944
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14945
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14946
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14947
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14948
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14949
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14950
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14951
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14952
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14953
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14954
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14955
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14956
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14957
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14958
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14959
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14960
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14961
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14962
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14963
	}/*function_time_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14964
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14965
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14966
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14967
 *TIME_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14968
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14969
	case function_time_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14970
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14971
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14972
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14973
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14974
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14975
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14976
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14977
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14978
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14979
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14980
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14981
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14982
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14983
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14984
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14985
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14986
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14987
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14988
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14989
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14990
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14991
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14992
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14993
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14994
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14995
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14996
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14997
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14998
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 14999
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15000
	}/*function_time_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15001
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15002
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15003
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15004
 *TIME_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15005
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15006
	case function_time_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15007
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15008
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15009
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15010
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15011
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15012
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15013
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15014
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15015
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15016
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15017
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15018
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15019
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15020
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15021
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15022
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15023
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15024
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15025
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15026
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15027
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15028
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15029
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15030
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15031
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15032
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15033
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15034
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15035
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15036
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15037
	}/*function_time_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15038
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15039
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15040
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15041
 *TIME_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15042
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15043
	case function_time_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15044
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15045
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15046
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15047
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15048
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15049
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15050
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15051
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15052
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15053
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15054
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15055
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15056
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15057
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15058
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15059
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15060
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15061
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15062
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15063
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15064
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15065
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15066
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15067
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15068
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15069
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15070
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15071
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15072
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15073
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15074
	}/*function_time_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15075
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15076
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15077
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15078
 *TIME_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15079
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15080
	case function_time_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15081
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15082
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15083
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15084
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15085
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15086
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15087
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15088
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15089
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15090
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15091
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15092
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15093
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15094
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15095
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15096
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15097
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15098
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15099
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15100
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15101
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15102
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15103
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15104
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15105
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15106
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15107
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15108
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15109
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15110
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15111
	}/*function_time_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15112
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15113
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15114
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15115
 *TIME_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15116
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15117
	case function_time_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15118
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15119
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15120
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15121
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15122
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15123
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15124
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15125
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15126
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15127
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15128
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15129
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15130
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15131
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15132
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15133
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15134
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15135
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15136
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15137
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15138
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15139
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15140
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15141
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15142
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15143
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15144
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15145
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15146
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15147
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15148
	}/*function_time_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15149
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15150
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15151
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15152
 *TIME_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15153
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15154
	case function_time_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15155
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15156
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15157
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15158
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15159
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15160
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15161
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15162
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15163
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15164
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15165
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15166
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15167
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15168
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15169
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15170
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15171
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15172
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15173
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15174
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15175
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15176
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15177
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15178
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15179
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15180
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15181
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15182
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15183
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15184
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15185
	}/*function_time_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15186
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15187
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15188
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15189
 *TIME_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15190
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15191
	case function_time_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15192
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15193
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15194
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15195
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15196
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15197
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15198
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15199
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15200
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15201
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15202
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15203
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15204
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15205
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15206
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15207
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15208
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15209
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15210
				s4o.print("#error TIME_TO_TIME not implemented!");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15211
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15212
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15213
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15214
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15215
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15216
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15217
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15218
	}/*function_time_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15219
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15220
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15221
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15222
 *TIME_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15223
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15224
	case function_time_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15225
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15226
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15227
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15228
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15229
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15230
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15231
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15232
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15233
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15234
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15235
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15236
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15237
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15238
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15239
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15240
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15241
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15242
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15243
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15244
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15245
				s4o.print(")real_to_time(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15246
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15247
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15248
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15249
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15250
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15251
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15252
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15253
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15254
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15255
	}/*function_time_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15256
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15257
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15258
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15259
 *INT_TO_REAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15260
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15261
	case function_int_to_real :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15262
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15263
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15264
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15265
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15266
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15267
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15268
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15269
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15270
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15271
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15272
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15273
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15274
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15275
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15276
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15277
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15278
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15279
				symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15280
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15281
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15282
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15283
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15284
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15285
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15286
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15287
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15288
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15289
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15290
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15291
	}/*function_int_to_real*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15292
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15293
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15294
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15295
 *INT_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15296
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15297
	case function_int_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15298
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15299
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15300
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15301
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15302
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15303
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15304
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15305
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15306
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15307
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15308
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15309
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15310
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15311
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15312
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15313
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15314
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15315
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15316
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15317
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15318
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15319
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15320
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15321
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15322
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15323
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15324
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15325
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15326
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15327
	}/*function_int_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15328
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15329
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15330
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15331
 *INT_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15332
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15333
	case function_int_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15334
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15335
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15336
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15337
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15338
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15339
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15340
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15341
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15342
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15343
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15344
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15345
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15346
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15347
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15348
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15349
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15350
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15351
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15352
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15353
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15354
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15355
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15356
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15357
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15358
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15359
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15360
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15361
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15362
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15363
	}/*function_int_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15364
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15365
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15366
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15367
 *INT_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15368
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15369
	case function_int_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15370
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15371
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15372
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15373
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15374
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15375
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15376
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15377
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15378
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15379
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15380
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15381
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15382
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15383
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15384
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15385
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15386
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15387
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15388
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15389
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15390
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15391
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15392
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15393
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15394
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15395
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15396
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15397
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15398
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15399
	}/*function_int_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15400
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15401
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15402
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15403
 *INT_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15404
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15405
	case function_int_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15406
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15407
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15408
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15409
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15410
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15411
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15412
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15413
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15414
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15415
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15416
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15417
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15418
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15419
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15420
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15421
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15422
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15423
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15424
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15425
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15426
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15427
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15428
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15429
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15430
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15431
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15432
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15433
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15434
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15435
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15436
	}/*function_int_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15437
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15438
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15439
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15440
 *INT_TO_DWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15441
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15442
	case function_int_to_dword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15443
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15444
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15445
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15446
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15447
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15448
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15449
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15450
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15451
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15452
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15453
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15454
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15455
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15456
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15457
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15458
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15459
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15460
				symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15461
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15462
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15463
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15464
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15465
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15466
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15467
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15468
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15469
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15470
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15471
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15472
	}/*function_int_to_dword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15473
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15474
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15475
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15476
 *INT_TO_DT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15477
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15478
	case function_int_to_dt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15479
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15480
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15481
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15482
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15483
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15484
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15485
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15486
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15487
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15488
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15489
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15490
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15491
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15492
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15493
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15494
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15495
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15496
				symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15497
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15498
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15499
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15500
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15501
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15502
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15503
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15504
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15505
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15506
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15507
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15508
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15509
	}/*function_int_to_dt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15510
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15511
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15512
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15513
 *INT_TO_TOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15514
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15515
	case function_int_to_tod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15516
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15517
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15518
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15519
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15520
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15521
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15522
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15523
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15524
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15525
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15526
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15527
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15528
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15529
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15530
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15531
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15532
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15533
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15534
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15535
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15536
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15537
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15538
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15539
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15540
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15541
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15542
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15543
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15544
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15545
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15546
	}/*function_int_to_tod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15547
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15548
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15549
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15550
 *INT_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15551
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15552
	case function_int_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15553
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15554
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15555
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15556
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15557
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15558
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15559
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15560
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15561
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15562
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15563
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15564
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15565
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15566
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15567
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15568
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15569
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15570
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15571
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15572
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15573
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15574
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15575
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15576
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15577
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15578
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15579
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15580
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15581
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15582
	}/*function_int_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15583
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15584
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15585
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15586
 *INT_TO_WORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15587
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15588
	case function_int_to_word :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15589
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15590
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15591
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15592
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15593
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15594
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15595
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15596
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15597
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15598
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15599
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15600
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15601
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15602
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15603
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15604
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15605
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15606
				symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15607
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15608
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15609
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15610
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15611
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15612
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15613
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15614
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15615
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15616
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15617
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15618
	}/*function_int_to_word*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15619
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15620
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15621
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15622
 *INT_TO_WSTRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15623
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15624
	case function_int_to_wstring :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15625
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15626
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15627
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15628
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15629
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15630
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15631
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15632
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15633
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15634
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15635
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15636
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15637
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15638
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15639
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15640
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15641
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15642
				symbol_c * return_type_symbol = &search_constant_type_c::wstring_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15643
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15644
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15645
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15646
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15647
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15648
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15649
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15650
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15651
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15652
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15653
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15654
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15655
	}/*function_int_to_wstring*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15656
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15657
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15658
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15659
 *INT_TO_STRING
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15660
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15661
	case function_int_to_string :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15662
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15663
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15664
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15665
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15666
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15667
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15668
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15669
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15670
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15671
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15672
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15673
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15674
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15675
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15676
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15677
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15678
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15679
				symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15680
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15681
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15682
				s4o.print(")string_to_int(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15683
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15684
				s4o.print(", 10)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15685
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15686
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15687
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15688
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15689
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15690
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15691
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15692
	}/*function_int_to_string*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15693
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15694
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15695
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15696
 *INT_TO_LWORD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15697
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15698
	case function_int_to_lword :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15699
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15700
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15701
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15702
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15703
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15704
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15705
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15706
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15707
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15708
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15709
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15710
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15711
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15712
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15713
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15714
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15715
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15716
				symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15717
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15718
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15719
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15720
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15721
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15722
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15723
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15724
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15725
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15726
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15727
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15728
	}/*function_int_to_lword*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15729
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15730
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15731
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15732
 *INT_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15733
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15734
	case function_int_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15735
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15736
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15737
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15738
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15739
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15740
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15741
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15742
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15743
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15744
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15745
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15746
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15747
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15748
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15749
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15750
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15751
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15752
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15753
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15754
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15755
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15756
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15757
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15758
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15759
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15760
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15761
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15762
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15763
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15764
	}/*function_int_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15765
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15766
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15767
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15768
 *INT_TO_LREAL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15769
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15770
	case function_int_to_lreal :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15771
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15772
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15773
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15774
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15775
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15776
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15777
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15778
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15779
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15780
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15781
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15782
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15783
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15784
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15785
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15786
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15787
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15788
				symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15789
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15790
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15791
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15792
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15793
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15794
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15795
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15796
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15797
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15798
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15799
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15800
	}/*function_int_to_lreal*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15801
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15802
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15803
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15804
 *INT_TO_BYTE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15805
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15806
	case function_int_to_byte :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15807
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15808
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15809
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15810
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15811
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15812
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15813
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15814
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15815
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15816
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15817
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15818
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15819
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15820
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15821
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15822
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15823
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15824
				symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15825
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15826
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15827
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15828
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15829
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15830
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15831
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15832
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15833
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15834
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15835
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15836
	}/*function_int_to_byte*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15837
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15838
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15839
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15840
 *INT_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15841
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15842
	case function_int_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15843
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15844
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15845
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15846
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15847
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15848
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15849
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15850
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15851
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15852
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15853
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15854
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15855
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15856
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15857
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15858
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15859
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15860
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15861
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15862
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15863
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15864
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15865
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15866
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15867
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15868
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15869
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15870
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15871
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15872
	}/*function_int_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15873
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15874
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15875
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15876
 *INT_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15877
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15878
	case function_int_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15879
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15880
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15881
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15882
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15883
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15884
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15885
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15886
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15887
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15888
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15889
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15890
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15891
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15892
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15893
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15894
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15895
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15896
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15897
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15898
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15899
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15900
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15901
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15902
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15903
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15904
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15905
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15906
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15907
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15908
	}/*function_int_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15909
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15910
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15911
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15912
 *INT_TO_BOOL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15913
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15914
	case function_int_to_bool :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15915
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15916
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15917
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15918
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15919
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15920
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15921
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15922
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15923
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15924
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15925
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15926
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15927
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15928
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15929
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15930
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15931
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15932
				symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15933
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15934
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15935
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15936
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15937
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15938
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15939
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15940
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15941
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15942
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15943
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15944
	}/*function_int_to_bool*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15945
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15946
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15947
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15948
 *INT_TO_TIME
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15949
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15950
	case function_int_to_time :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15951
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15952
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15953
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15954
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15955
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15956
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15957
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15958
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15959
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15960
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15961
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15962
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15963
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15964
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15965
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15966
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15967
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15968
				symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15969
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15970
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15971
				s4o.print(")time_to_real(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15972
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15973
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15974
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15975
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15976
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15977
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15978
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15979
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15980
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15981
	}/*function_int_to_time*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15982
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15983
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15984
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15985
 *INT_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15986
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15987
	case function_int_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15988
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15989
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15990
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15991
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15992
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15993
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15994
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15995
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15996
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15997
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15998
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 15999
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16000
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16001
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16002
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16003
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16004
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16005
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16006
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16007
				return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16008
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16009
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16010
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16011
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16012
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16013
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16014
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16015
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16016
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16017
	}/*function_int_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16018
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16019
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16020
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16021
 *TRUNC
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16022
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16023
	case function_trunc :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16024
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16025
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16026
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16027
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16028
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16029
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16030
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16031
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16032
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16033
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16034
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16035
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16036
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16037
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16038
			if(search_expression_type->is_real_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16039
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16040
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16041
				symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16042
				s4o.print("(int)");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16043
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16044
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16045
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16046
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16047
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16048
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16049
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16050
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16051
	}/*function_trunc*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16052
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16053
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16054
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16055
 *BCD_TO_SINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16056
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16057
	case function_bcd_to_sint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16058
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16059
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16060
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16061
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16062
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16063
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16064
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16065
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16066
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16067
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16068
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16069
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16070
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16071
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16072
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16073
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16074
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16075
				symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16076
				s4o.print("__bcd_to_something(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16077
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16078
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16079
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16080
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16081
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16082
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16083
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16084
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16085
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16086
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16087
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16088
	}/*function_bcd_to_sint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16089
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16090
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16091
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16092
 *BCD_TO_LINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16093
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16094
	case function_bcd_to_lint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16095
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16096
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16097
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16098
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16099
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16100
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16101
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16102
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16103
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16104
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16105
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16106
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16107
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16108
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16109
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16110
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16111
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16112
				symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16113
				s4o.print("__bcd_to_something(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16114
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16115
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16116
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16117
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16118
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16119
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16120
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16121
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16122
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16123
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16124
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16125
	}/*function_bcd_to_lint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16126
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16127
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16128
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16129
 *BCD_TO_DINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16130
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16131
	case function_bcd_to_dint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16132
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16133
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16134
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16135
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16136
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16137
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16138
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16139
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16140
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16141
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16142
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16143
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16144
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16145
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16146
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16147
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16148
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16149
				symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16150
				s4o.print("__bcd_to_something(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16151
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16152
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16153
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16154
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16155
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16156
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16157
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16158
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16159
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16160
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16161
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16162
	}/*function_bcd_to_dint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16163
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16164
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16165
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16166
 *BCD_TO_UDINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16167
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16168
	case function_bcd_to_udint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16169
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16170
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16171
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16172
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16173
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16174
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16175
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16176
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16177
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16178
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16179
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16180
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16181
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16182
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16183
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16184
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16185
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16186
				symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16187
				s4o.print("__bcd_to_something(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16188
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16189
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16190
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16191
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16192
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16193
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16194
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16195
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16196
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16197
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16198
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16199
	}/*function_bcd_to_udint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16200
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16201
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16202
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16203
 *BCD_TO_UINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16204
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16205
	case function_bcd_to_uint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16206
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16207
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16208
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16209
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16210
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16211
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16212
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16213
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16214
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16215
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16216
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16217
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16218
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16219
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16220
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16221
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16222
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16223
				symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16224
				s4o.print("__bcd_to_something(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16225
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16226
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16227
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16228
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16229
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16230
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16231
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16232
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16233
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16234
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16235
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16236
	}/*function_bcd_to_uint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16237
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16238
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16239
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16240
 *BCD_TO_USINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16241
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16242
	case function_bcd_to_usint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16243
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16244
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16245
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16246
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16247
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16248
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16249
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16250
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16251
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16252
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16253
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16254
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16255
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16256
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16257
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16258
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16259
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16260
				symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16261
				s4o.print("__bcd_to_something(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16262
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16263
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16264
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16265
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16266
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16267
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16268
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16269
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16270
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16271
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16272
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16273
	}/*function_bcd_to_usint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16274
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16275
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16276
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16277
 *BCD_TO_ULINT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16278
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16279
	case function_bcd_to_ulint :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16280
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16281
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16282
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16283
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16284
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16285
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16286
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16287
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16288
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16289
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16290
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16291
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16292
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16293
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16294
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16295
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16296
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16297
				symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16298
				s4o.print("__bcd_to_something(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16299
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16300
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16301
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16302
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16303
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16304
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16305
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16306
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16307
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16308
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16309
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16310
	}/*function_bcd_to_ulint*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16311
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16312
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16313
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16314
 *BCD_TO_INT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16315
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16316
	case function_bcd_to_int :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16317
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16318
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16319
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16320
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16321
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16322
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16323
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16324
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16325
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16326
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16327
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16328
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16329
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16330
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16331
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16332
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16333
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16334
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16335
				s4o.print("__bcd_to_something(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16336
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16337
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16338
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16339
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16340
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16341
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16342
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16343
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16344
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16345
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16346
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16347
	}/*function_bcd_to_int*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16348
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16349
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16350
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16351
 *SINT_TO_BCD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16352
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16353
	case function_sint_to_bcd :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16354
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16355
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16356
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16357
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16358
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16359
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16360
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16361
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16362
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16363
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16364
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16365
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16366
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16367
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16368
			if (typeid(*last_type_symbol) == typeid(sint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16369
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16370
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16371
				symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16372
				s4o.print("__something_to_bcd(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16373
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16374
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16375
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16376
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16377
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16378
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16379
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16380
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16381
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16382
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16383
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16384
	}/*function_sint_to_bcd*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16385
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16386
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16387
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16388
 *LINT_TO_BCD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16389
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16390
	case function_lint_to_bcd :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16391
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16392
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16393
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16394
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16395
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16396
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16397
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16398
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16399
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16400
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16401
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16402
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16403
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16404
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16405
			if (typeid(*last_type_symbol) == typeid(lint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16406
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16407
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16408
				symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16409
				s4o.print("__something_to_bcd(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16410
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16411
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16412
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16413
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16414
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16415
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16416
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16417
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16418
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16419
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16420
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16421
	}/*function_lint_to_bcd*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16422
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16423
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16424
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16425
 *DINT_TO_BCD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16426
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16427
	case function_dint_to_bcd :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16428
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16429
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16430
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16431
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16432
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16433
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16434
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16435
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16436
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16437
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16438
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16439
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16440
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16441
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16442
			if (typeid(*last_type_symbol) == typeid(dint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16443
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16444
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16445
				symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16446
				s4o.print("__something_to_bcd(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16447
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16448
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16449
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16450
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16451
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16452
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16453
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16454
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16455
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16456
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16457
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16458
	}/*function_dint_to_bcd*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16459
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16460
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16461
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16462
 *UDINT_TO_BCD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16463
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16464
	case function_udint_to_bcd :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16465
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16466
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16467
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16468
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16469
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16470
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16471
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16472
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16473
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16474
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16475
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16476
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16477
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16478
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16479
			if (typeid(*last_type_symbol) == typeid(udint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16480
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16481
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16482
				symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16483
				s4o.print("__something_to_bcd(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16484
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16485
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16486
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16487
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16488
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16489
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16490
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16491
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16492
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16493
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16494
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16495
	}/*function_udint_to_bcd*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16496
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16497
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16498
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16499
 *UINT_TO_BCD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16500
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16501
	case function_uint_to_bcd :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16502
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16503
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16504
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16505
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16506
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16507
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16508
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16509
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16510
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16511
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16512
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16513
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16514
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16515
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16516
			if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16517
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16518
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16519
				symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16520
				s4o.print("__something_to_bcd(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16521
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16522
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16523
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16524
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16525
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16526
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16527
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16528
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16529
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16530
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16531
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16532
	}/*function_uint_to_bcd*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16533
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16534
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16535
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16536
 *USINT_TO_BCD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16537
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16538
	case function_usint_to_bcd :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16539
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16540
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16541
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16542
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16543
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16544
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16545
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16546
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16547
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16548
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16549
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16550
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16551
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16552
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16553
			if (typeid(*last_type_symbol) == typeid(usint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16554
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16555
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16556
				symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16557
				s4o.print("__something_to_bcd(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16558
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16559
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16560
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16561
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16562
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16563
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16564
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16565
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16566
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16567
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16568
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16569
	}/*function_usint_to_bcd*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16570
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16571
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16572
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16573
 *ULINT_TO_BCD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16574
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16575
	case function_ulint_to_bcd :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16576
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16577
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16578
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16579
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16580
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16581
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16582
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16583
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16584
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16585
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16586
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16587
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16588
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16589
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16590
			if (typeid(*last_type_symbol) == typeid(ulint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16591
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16592
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16593
				symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16594
				s4o.print("__something_to_bcd(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16595
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16596
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16597
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16598
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16599
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16600
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16601
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16602
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16603
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16604
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16605
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16606
	}/*function_ulint_to_bcd*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16607
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16608
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16609
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16610
 *INT_TO_BCD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16611
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16612
	case function_int_to_bcd :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16613
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16614
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16615
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16616
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16617
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16618
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16619
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16620
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16621
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16622
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16623
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16624
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16625
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16626
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16627
			if (typeid(*last_type_symbol) == typeid(int_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16628
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16629
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16630
				symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16631
				s4o.print("__something_to_bcd(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16632
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16633
				s4o.print("),&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16634
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16635
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16636
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16637
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16638
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16639
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16640
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16641
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16642
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16643
	}/*function_int_to_bcd*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16644
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16645
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16646
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16647
 *DATE_AND_TIME_TO_TIME_OF_DAY
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16648
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16649
	case function_date_and_time_to_time_of_day :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16650
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16651
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16652
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16653
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16654
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16655
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16656
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16657
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16658
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16659
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16660
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16661
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16662
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16663
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16664
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16665
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16666
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16667
				symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16668
				s4o.print("__date_and_time_to_time_of_day(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16669
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16670
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16671
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16672
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16673
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16674
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16675
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16676
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16677
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16678
	}/*function_date_and_time_to_time_of_day*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16679
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16680
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16681
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16682
 *DATE_AND_TIME_TO_DATE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16683
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16684
	case function_date_and_time_to_date :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16685
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16686
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16687
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16688
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16689
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16690
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16691
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16692
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16693
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16694
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16695
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16696
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16697
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16698
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16699
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16700
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16701
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16702
				symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16703
				s4o.print("__date_and_time_to_time_of_day(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16704
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16705
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16706
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16707
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16708
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16709
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16710
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16711
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16712
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16713
	}/*function_date_and_time_to_date*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16714
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16715
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16716
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16717
 *ABS
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16718
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16719
	case function_abs :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16720
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16721
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16722
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16723
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16724
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16725
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16726
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16727
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16728
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16729
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16730
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16731
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16732
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16733
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16734
			if(search_expression_type->is_num_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16735
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16736
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16737
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16738
				s4o.print("__abs_");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16739
				IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16740
				s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16741
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16742
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16743
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16744
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16745
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16746
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16747
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16748
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16749
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16750
	}/*function_abs*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16751
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16752
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16753
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16754
 *SQRT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16755
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16756
	case function_sqrt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16757
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16758
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16759
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16760
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16761
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16762
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16763
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16764
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16765
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16766
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16767
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16768
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16769
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16770
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16771
			if(search_expression_type->is_real_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16772
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16773
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16774
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16775
				s4o.print("sqrt(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16776
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16777
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16778
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16779
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16780
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16781
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16782
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16783
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16784
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16785
	}/*function_sqrt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16786
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16787
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16788
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16789
 *LN
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16790
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16791
	case function_ln :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16792
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16793
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16794
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16795
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16796
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16797
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16798
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16799
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16800
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16801
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16802
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16803
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16804
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16805
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16806
			if(search_expression_type->is_real_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16807
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16808
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16809
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16810
				s4o.print("ln(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16811
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16812
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16813
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16814
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16815
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16816
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16817
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16818
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16819
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16820
	}/*function_ln*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16821
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16822
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16823
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16824
 *LOG
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16825
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16826
	case function_log :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16827
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16828
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16829
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16830
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16831
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16832
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16833
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16834
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16835
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16836
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16837
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16838
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16839
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16840
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16841
			if(search_expression_type->is_real_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16842
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16843
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16844
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16845
				s4o.print("log(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16846
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16847
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16848
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16849
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16850
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16851
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16852
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16853
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16854
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16855
	}/*function_log*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16856
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16857
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16858
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16859
 *EXP
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16860
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16861
	case function_exp :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16862
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16863
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16864
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16865
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16866
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16867
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16868
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16869
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16870
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16871
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16872
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16873
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16874
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16875
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16876
			if(search_expression_type->is_real_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16877
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16878
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16879
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16880
				s4o.print("exp(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16881
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16882
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16883
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16884
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16885
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16886
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16887
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16888
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16889
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16890
	}/*function_exp*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16891
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16892
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16893
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16894
 *SIN
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16895
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16896
	case function_sin :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16897
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16898
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16899
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16900
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16901
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16902
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16903
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16904
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16905
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16906
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16907
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16908
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16909
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16910
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16911
			if(search_expression_type->is_real_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16912
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16913
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16914
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16915
				s4o.print("sin(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16916
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16917
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16918
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16919
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16920
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16921
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16922
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16923
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16924
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16925
	}/*function_sin*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16926
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16927
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16928
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16929
 *COS
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16930
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16931
	case function_cos :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16932
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16933
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16934
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16935
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16936
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16937
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16938
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16939
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16940
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16941
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16942
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16943
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16944
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16945
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16946
			if(search_expression_type->is_real_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16947
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16948
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16949
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16950
				s4o.print("cos(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16951
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16952
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16953
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16954
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16955
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16956
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16957
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16958
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16959
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16960
	}/*function_cos*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16961
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16962
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16963
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16964
 *TAN
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16965
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16966
	case function_tan :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16967
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16968
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16969
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16970
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16971
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16972
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16973
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16974
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16975
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16976
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16977
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16978
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16979
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16980
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 16981
			if(search_expression_type->is_real_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16982
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16983
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16984
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16985
				s4o.print("tan(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16986
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16987
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16988
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16989
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16990
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16991
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16992
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16993
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16994
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16995
	}/*function_tan*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16996
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16997
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16998
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 16999
 *ASIN
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17000
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17001
	case function_asin :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17002
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17003
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17004
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17005
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17006
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17007
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17008
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17009
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17010
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17011
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17012
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17013
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17014
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17015
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17016
			if(search_expression_type->is_real_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17017
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17018
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17019
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17020
				s4o.print("asin(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17021
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17022
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17023
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17024
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17025
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17026
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17027
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17028
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17029
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17030
	}/*function_asin*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17031
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17032
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17033
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17034
 *ACOS
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17035
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17036
	case function_acos :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17037
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17038
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17039
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17040
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17041
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17042
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17043
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17044
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17045
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17046
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17047
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17048
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17049
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17050
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17051
			if(search_expression_type->is_real_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17052
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17053
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17054
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17055
				s4o.print("acos(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17056
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17057
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17058
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17059
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17060
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17061
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17062
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17063
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17064
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17065
	}/*function_acos*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17066
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17067
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17068
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17069
 *ATAN
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17070
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17071
	case function_atan :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17072
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17073
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17074
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17075
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17076
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17077
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17078
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17079
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17080
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17081
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17082
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17083
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17084
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17085
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17086
			if(search_expression_type->is_real_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17087
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17088
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17089
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17090
				s4o.print("atan(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17091
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17092
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17093
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17094
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17095
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17096
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17097
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17098
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17099
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17100
	}/*function_atan*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17101
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17102
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17103
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17104
 *ADD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17105
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17106
	case function_add :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17107
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17108
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17109
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17110
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17111
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17112
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17113
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17114
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17115
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17116
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17117
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17118
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17119
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17120
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17121
			if(search_expression_type->is_num_type(IN1_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17122
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17123
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17124
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17125
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17126
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17127
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17128
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17129
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17130
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17131
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17132
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17133
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17134
					
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17135
					if(search_expression_type->is_num_type(IN2_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17136
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17137
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17138
						symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17139
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17140
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17141
						s4o.print("+");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17142
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17143
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17144
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17145
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17146
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17147
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17148
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17149
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17150
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17151
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17152
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17153
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17154
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17155
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17156
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17157
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17158
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17159
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17160
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17161
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17162
								s4o.print("+");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17163
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17164
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17165
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17166
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17167
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17168
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17169
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17170
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17171
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17172
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17173
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17174
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17175
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17176
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17177
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17178
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17179
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17180
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17181
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17182
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17183
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17184
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17185
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17186
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17187
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17188
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17189
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17190
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17191
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17192
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17193
					if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17194
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17195
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17196
						symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17197
						s4o.print("__time_add(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17198
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17199
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17200
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17201
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17202
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17203
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17204
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17205
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17206
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17207
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17208
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17209
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17210
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17211
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17212
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17213
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17214
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17215
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17216
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17217
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17218
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17219
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17220
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17221
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17222
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17223
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17224
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17225
					if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17226
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17227
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17228
						symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17229
						s4o.print("__time_add(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17230
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17231
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17232
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17233
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17234
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17235
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17236
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17237
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17238
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17239
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17240
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17241
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17242
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17243
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17244
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17245
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17246
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17247
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17248
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17249
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17250
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17251
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17252
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17253
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17254
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17255
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17256
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17257
					if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17258
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17259
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17260
						symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17261
						s4o.print("__time_add(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17262
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17263
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17264
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17265
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17266
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17267
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17268
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17269
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17270
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17271
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17272
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17273
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17274
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17275
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17276
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17277
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17278
	}/*function_add*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17279
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17280
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17281
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17282
 *MUL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17283
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17284
	case function_mul :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17285
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17286
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17287
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17288
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17289
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17290
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17291
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17292
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17293
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17294
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17295
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17296
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17297
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17298
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17299
			if(search_expression_type->is_num_type(IN1_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17300
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17301
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17302
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17303
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17304
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17305
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17306
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17307
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17308
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17309
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17310
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17311
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17312
					
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17313
					if(search_expression_type->is_num_type(IN2_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17314
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17315
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17316
						symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17317
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17318
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17319
						s4o.print("*");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17320
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17321
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17322
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17323
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17324
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17325
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17326
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17327
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17328
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17329
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17330
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17331
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17332
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17333
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17334
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17335
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17336
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17337
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17338
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17339
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17340
								s4o.print("*");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17341
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17342
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17343
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17344
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17345
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17346
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17347
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17348
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17349
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17350
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17351
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17352
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17353
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17354
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17355
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17356
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17357
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17358
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17359
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17360
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17361
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17362
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17363
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17364
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17365
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17366
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17367
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17368
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17369
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17370
					
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17371
					if(search_expression_type->is_num_type(IN2_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17372
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17373
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17374
						symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17375
						s4o.print("__time_mul(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17376
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17377
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17378
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17379
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17380
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17381
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17382
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17383
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17384
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17385
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17386
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17387
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17388
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17389
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17390
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17391
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17392
	}/*function_mul*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17393
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17394
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17395
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17396
 *SUB
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17397
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17398
	case function_sub :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17399
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17400
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17401
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17402
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17403
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17404
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17405
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17406
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17407
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17408
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17409
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17410
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17411
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17412
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17413
			if(search_expression_type->is_num_type(IN1_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17414
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17415
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17416
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17417
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17418
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17419
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17420
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17421
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17422
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17423
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17424
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17425
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17426
					
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17427
					if(search_expression_type->is_num_type(IN2_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17428
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17429
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17430
						symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17431
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17432
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17433
						s4o.print("-");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17434
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17435
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17436
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17437
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17438
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17439
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17440
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17441
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17442
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17443
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17444
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17445
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17446
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17447
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17448
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17449
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17450
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17451
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17452
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17453
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17454
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17455
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17456
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17457
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17458
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17459
					if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17460
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17461
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17462
						symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17463
						s4o.print("__time_sub(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17464
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17465
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17466
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17467
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17468
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17469
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17470
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17471
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17472
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17473
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17474
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17475
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17476
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17477
			if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17478
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17479
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17480
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17481
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17482
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17483
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17484
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17485
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17486
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17487
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17488
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17489
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17490
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17491
					if (typeid(*last_type_symbol) == typeid(dt_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17492
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17493
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17494
						symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17495
						s4o.print("__time_sub(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17496
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17497
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17498
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17499
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17500
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17501
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17502
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17503
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17504
					if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17505
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17506
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17507
						symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17508
						s4o.print("__time_sub(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17509
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17510
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17511
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17512
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17513
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17514
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17515
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17516
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17517
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17518
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17519
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17520
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17521
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17522
			if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17523
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17524
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17525
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17526
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17527
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17528
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17529
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17530
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17531
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17532
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17533
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17534
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17535
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17536
					if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17537
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17538
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17539
						symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17540
						s4o.print("__time_sub(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17541
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17542
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17543
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17544
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17545
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17546
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17547
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17548
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17549
					if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17550
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17551
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17552
						symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17553
						s4o.print("__time_sub(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17554
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17555
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17556
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17557
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17558
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17559
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17560
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17561
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17562
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17563
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17564
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17565
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17566
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17567
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17568
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17569
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17570
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17571
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17572
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17573
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17574
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17575
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17576
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17577
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17578
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17579
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17580
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17581
					if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17582
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17583
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17584
						symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17585
						s4o.print("__time_sub(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17586
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17587
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17588
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17589
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17590
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17591
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17592
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17593
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17594
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17595
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17596
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17597
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17598
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17599
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17600
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17601
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17602
	}/*function_sub*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17603
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17604
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17605
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17606
 *DIV
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17607
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17608
	case function_div :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17609
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17610
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17611
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17612
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17613
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17614
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17615
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17616
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17617
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17618
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17619
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17620
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17621
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17622
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17623
			if(search_expression_type->is_num_type(IN1_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17624
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17625
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17626
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17627
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17628
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17629
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17630
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17631
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17632
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17633
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17634
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17635
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17636
					
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17637
					if(search_expression_type->is_num_type(IN2_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17638
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17639
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17640
						symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17641
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17642
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17643
						s4o.print("/");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17644
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17645
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17646
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17647
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17648
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17649
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17650
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17651
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17652
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17653
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17654
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17655
			if (typeid(*last_type_symbol) == typeid(time_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17656
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17657
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17658
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17659
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17660
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17661
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17662
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17663
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17664
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17665
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17666
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17667
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17668
					
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17669
					if(search_expression_type->is_num_type(IN2_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17670
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17671
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17672
						symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17673
						s4o.print("__time_div(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17674
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17675
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17676
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17677
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17678
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17679
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17680
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17681
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17682
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17683
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17684
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17685
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17686
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17687
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17688
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17689
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17690
	}/*function_div*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17691
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17692
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17693
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17694
 *MOD
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17695
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17696
	case function_mod :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17697
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17698
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17699
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17700
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17701
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17702
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17703
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17704
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17705
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17706
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17707
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17708
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17709
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17710
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17711
			if(search_expression_type->is_num_type(IN1_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17712
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17713
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17714
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17715
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17716
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17717
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17718
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17719
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17720
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17721
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17722
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17723
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17724
					
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17725
					if(search_expression_type->is_num_type(IN2_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17726
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17727
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17728
						symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17729
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17730
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17731
						s4o.print("%");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17732
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17733
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17734
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17735
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17736
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17737
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17738
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17739
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17740
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17741
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17742
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17743
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17744
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17745
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17746
	}/*function_mod*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17747
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17748
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17749
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17750
 *EXPT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17751
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17752
	case function_expt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17753
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17754
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17755
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17756
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17757
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17758
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17759
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17760
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17761
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17762
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17763
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17764
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17765
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17766
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17767
			if(search_expression_type->is_num_type(IN1_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17768
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17769
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17770
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17771
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17772
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17773
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17774
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17775
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17776
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17777
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17778
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17779
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17780
					
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17781
					if(search_expression_type->is_num_type(IN2_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17782
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17783
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17784
						symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17785
						s4o.print("pow(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17786
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17787
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17788
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17789
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17790
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17791
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17792
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17793
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17794
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17795
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17796
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17797
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17798
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17799
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17800
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17801
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17802
	}/*function_expt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17803
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17804
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17805
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17806
 *MOVE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17807
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17808
	case function_move :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17809
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17810
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17811
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17812
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17813
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17814
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17815
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17816
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17817
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17818
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17819
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17820
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17821
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17822
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17823
			if(search_expression_type->is_num_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17824
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17825
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17826
				symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17827
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17828
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17829
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17830
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17831
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17832
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17833
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17834
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17835
	}/*function_move*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17836
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17837
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17838
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17839
 *SHL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17840
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17841
	case function_shl :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17842
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17843
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17844
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17845
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17846
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17847
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17848
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17849
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17850
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17851
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17852
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17853
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17854
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17855
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17856
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17857
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17858
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17859
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17860
					identifier_c param_name("N");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17861
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17862
					symbol_c *N_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17863
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17864
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17865
					if (N_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17866
					  N_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17867
					symbol_c *N_type_symbol = search_expression_type->get_type(N_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17868
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17869
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17870
					if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17871
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17872
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17873
						symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17874
						IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17875
						s4o.print("<<");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17876
						N_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17877
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17878
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17879
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17880
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17881
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17882
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17883
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17884
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17885
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17886
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17887
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17888
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17889
	}/*function_shl*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17890
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17891
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17892
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17893
 *SHR
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17894
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17895
	case function_shr :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17896
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17897
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17898
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17899
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17900
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17901
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17902
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17903
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17904
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17905
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17906
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17907
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17908
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17909
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17910
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17911
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17912
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17913
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17914
					identifier_c param_name("N");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17915
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17916
					symbol_c *N_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17917
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17918
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17919
					if (N_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17920
					  N_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17921
					symbol_c *N_type_symbol = search_expression_type->get_type(N_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17922
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17923
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17924
					if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17925
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17926
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17927
						symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17928
						IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17929
						s4o.print(">>");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17930
						N_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17931
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17932
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17933
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17934
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17935
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17936
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17937
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17938
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17939
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17940
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17941
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17942
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17943
	}/*function_shr*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17944
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17945
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17946
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17947
 *ROR
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17948
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17949
	case function_ror :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17950
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17951
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17952
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17953
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17954
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17955
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17956
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17957
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17958
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17959
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17960
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17961
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17962
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17963
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 17964
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17965
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17966
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17967
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17968
					identifier_c param_name("N");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17969
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17970
					symbol_c *N_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17971
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17972
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17973
					if (N_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17974
					  N_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17975
					symbol_c *N_type_symbol = search_expression_type->get_type(N_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17976
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17977
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17978
					if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17979
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17980
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17981
						symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17982
						s4o.print("__ror(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17983
						IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17984
						s4o.print("), &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17985
						IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17986
						s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17987
						N_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17988
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17989
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17990
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17991
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17992
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17993
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17994
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17995
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17996
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17997
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17998
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 17999
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18000
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18001
	}/*function_ror*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18002
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18003
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18004
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18005
 *ROL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18006
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18007
	case function_rol :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18008
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18009
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18010
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18011
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18012
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18013
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18014
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18015
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18016
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18017
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18018
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18019
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18020
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18021
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18022
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18023
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18024
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18025
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18026
					identifier_c param_name("N");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18027
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18028
					symbol_c *N_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18029
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18030
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18031
					if (N_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18032
					  N_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18033
					symbol_c *N_type_symbol = search_expression_type->get_type(N_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18034
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18035
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18036
					if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18037
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18038
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18039
						symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18040
						s4o.print("__rol(sizeof(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18041
						IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18042
						s4o.print("), &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18043
						IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18044
						s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18045
						N_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18046
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18047
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18048
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18049
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18050
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18051
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18052
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18053
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18054
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18055
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18056
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18057
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18058
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18059
	}/*function_rol*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18060
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18061
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18062
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18063
 *AND
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18064
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18065
	case function_and :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18066
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18067
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18068
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18069
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18070
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18071
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18072
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18073
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18074
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18075
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18076
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18077
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18078
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18079
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18080
			if(search_expression_type->is_binary_type(IN1_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18081
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18082
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18083
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18084
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18085
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18086
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18087
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18088
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18089
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18090
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18091
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18092
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18093
					
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18094
					if(search_expression_type->is_binary_type(IN2_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18095
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18096
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18097
						symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18098
						s4o.print("(");
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18099
						if (search_expression_type->is_bool_type(last_type_symbol))
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18100
						  s4o.print("(");
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18101
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18102
						s4o.print("&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18103
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18104
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18105
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18106
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18107
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18108
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18109
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18110
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18111
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18112
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18113
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18114
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18115
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18116
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18117
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18118
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18119
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18120
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18121
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18122
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18123
								s4o.print("&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18124
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18125
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18126
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18127
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18128
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18129
						s4o.print(")");
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18130
						if (search_expression_type->is_bool_type(last_type_symbol)) {
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18131
						  s4o.print("&1");
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18132
						  s4o.print(")");
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18133
						}
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18134
						s4o.print("");
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18135
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18136
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18137
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18138
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18139
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18140
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18141
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18142
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18143
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18144
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18145
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18146
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18147
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18148
	}/*function_and*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18149
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18150
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18151
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18152
 *OR
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18153
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18154
	case function_or :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18155
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18156
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18157
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18158
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18159
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18160
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18161
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18162
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18163
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18164
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18165
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18166
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18167
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18168
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18169
			if(search_expression_type->is_binary_type(IN1_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18170
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18171
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18172
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18173
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18174
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18175
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18176
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18177
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18178
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18179
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18180
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18181
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18182
					
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18183
					if(search_expression_type->is_binary_type(IN2_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18184
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18185
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18186
						symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18187
						s4o.print("(");
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18188
						if (search_expression_type->is_bool_type(last_type_symbol))
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18189
						  s4o.print("(");
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18190
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18191
						s4o.print("|");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18192
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18193
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18194
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18195
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18196
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18197
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18198
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18199
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18200
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18201
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18202
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18203
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18204
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18205
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18206
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18207
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18208
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18209
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18210
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18211
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18212
								s4o.print("|");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18213
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18214
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18215
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18216
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18217
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18218
						s4o.print(")");
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18219
						if (search_expression_type->is_bool_type(last_type_symbol)) {
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18220
						  s4o.print("&1");
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18221
						  s4o.print(")");
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18222
						}
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18223
						s4o.print("");
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18224
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18225
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18226
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18227
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18228
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18229
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18230
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18231
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18232
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18233
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18234
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18235
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18236
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18237
	}/*function_or*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18238
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18239
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18240
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18241
 *XOR
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18242
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18243
	case function_xor :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18244
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18245
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18246
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18247
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18248
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18249
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18250
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18251
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18252
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18253
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18254
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18255
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18256
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18257
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18258
			if(search_expression_type->is_binary_type(IN1_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18259
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18260
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18261
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18262
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18263
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18264
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18265
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18266
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18267
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18268
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18269
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18270
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18271
					
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18272
					if(search_expression_type->is_binary_type(IN2_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18273
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18274
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18275
						symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18276
						s4o.print("(");
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18277
						if (search_expression_type->is_bool_type(last_type_symbol))
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18278
						  s4o.print("(");
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18279
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18280
						s4o.print("^");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18281
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18282
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18283
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18284
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18285
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18286
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18287
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18288
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18289
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18290
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18291
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18292
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18293
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18294
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18295
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18296
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18297
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18298
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18299
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18300
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18301
								s4o.print("^");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18302
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18303
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18304
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18305
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18306
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18307
						s4o.print(")");
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18308
						if (search_expression_type->is_bool_type(last_type_symbol)) {
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18309
						  s4o.print("&1");
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18310
						  s4o.print(")");
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18311
						}
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18312
						s4o.print("");
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18313
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18314
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18315
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18316
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18317
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18318
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18319
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18320
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18321
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18322
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18323
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18324
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18325
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18326
	}/*function_xor*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18327
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18328
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18329
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18330
 *NOT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18331
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18332
	case function_not :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18333
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18334
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18335
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18336
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18337
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18338
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18339
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18340
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18341
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18342
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18343
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18344
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18345
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18346
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18347
			if(search_expression_type->is_binary_type(IN_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18348
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18349
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18350
				symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18351
				s4o.print("~");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18352
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18353
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18354
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18355
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18356
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18357
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18358
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18359
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18360
	}/*function_not*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18361
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18362
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18363
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18364
 *SEL
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18365
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18366
	case function_sel :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18367
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18368
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18369
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18370
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18371
			identifier_c param_name("G");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18372
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18373
			symbol_c *G_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18374
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18375
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18376
			if (G_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18377
			  G_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18378
			symbol_c *G_type_symbol = search_expression_type->get_type(G_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18379
			last_type_symbol = last_type_symbol && search_expression_type->is_same_type(G_type_symbol, last_type_symbol) ? search_expression_type->common_type(G_type_symbol, last_type_symbol) : G_type_symbol ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18380
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18381
			if (typeid(*last_type_symbol) == typeid(bool_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18382
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18383
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18384
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18385
					identifier_c param_name("IN0");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18386
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18387
					symbol_c *IN0_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18388
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18389
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18390
					if (IN0_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18391
					  IN0_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18392
					symbol_c *IN0_type_symbol = search_expression_type->get_type(IN0_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18393
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18394
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18395
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18396
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18397
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18398
						{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18399
							identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18400
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18401
							symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18402
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18403
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18404
							if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18405
							  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18406
							symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18407
							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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18408
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18409
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18410
							{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18411
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18412
								symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18413
								G_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18414
								s4o.print(" ? ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18415
								IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18416
								s4o.print(" :  ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18417
								IN0_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18418
								return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18419
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18420
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18421
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18422
							ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18423
						}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18424
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18425
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18426
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18427
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18428
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18429
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18430
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18431
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18432
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18433
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18434
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18435
	}/*function_sel*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18436
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18437
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18438
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18439
 *MAX
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18440
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18441
	case function_max :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18442
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18443
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18444
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18445
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18446
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18447
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18448
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18449
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18450
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18451
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18452
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18453
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18454
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18455
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18456
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18457
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18458
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18459
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18460
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18461
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18462
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18463
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18464
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18465
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18466
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18467
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18468
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18469
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18470
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18471
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18472
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18473
						symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18474
						s4o.print("__max_");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18475
						return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18476
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18477
						s4o.print_integer(nb_param);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18478
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18479
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18480
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18481
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18482
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18483
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18484
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18485
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18486
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18487
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18488
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18489
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18490
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18491
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18492
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18493
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18494
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18495
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18496
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18497
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18498
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18499
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18500
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18501
								s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18502
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18503
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18504
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18505
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18506
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18507
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18508
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18509
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18510
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18511
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18512
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18513
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18514
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18515
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18516
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18517
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18518
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18519
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18520
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18521
	}/*function_max*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18522
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18523
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18524
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18525
 *MIN
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18526
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18527
	case function_min :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18528
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18529
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18530
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18531
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18532
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18533
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18534
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18535
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18536
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18537
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18538
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18539
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18540
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18541
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18542
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18543
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18544
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18545
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18546
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18547
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18548
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18549
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18550
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18551
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18552
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18553
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18554
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18555
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18556
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18557
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18558
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18559
						symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18560
						s4o.print("__min_");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18561
						return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18562
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18563
						s4o.print_integer(nb_param);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18564
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18565
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18566
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18567
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18568
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18569
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18570
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18571
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18572
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18573
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18574
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18575
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18576
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18577
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18578
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18579
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18580
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18581
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18582
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18583
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18584
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18585
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18586
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18587
								s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18588
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18589
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18590
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18591
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18592
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18593
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18594
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18595
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18596
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18597
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18598
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18599
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18600
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18601
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18602
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18603
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18604
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18605
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18606
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18607
	}/*function_min*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18608
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18609
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18610
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18611
 *LIMIT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18612
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18613
	case function_limit :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18614
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18615
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18616
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18617
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18618
			identifier_c param_name("MN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18619
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18620
			symbol_c *MN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18621
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18622
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18623
			if (MN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18624
			  MN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18625
			symbol_c *MN_type_symbol = search_expression_type->get_type(MN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18626
			last_type_symbol = last_type_symbol && search_expression_type->is_same_type(MN_type_symbol, last_type_symbol) ? search_expression_type->common_type(MN_type_symbol, last_type_symbol) : MN_type_symbol ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18627
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18628
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18629
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18630
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18631
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18632
					identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18633
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18634
					symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18635
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18636
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18637
					if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18638
					  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18639
					symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18640
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18641
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18642
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18643
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18644
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18645
						{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18646
							identifier_c param_name("MX");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18647
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18648
							symbol_c *MX_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18649
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18650
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18651
							if (MX_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18652
							  MX_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18653
							symbol_c *MX_type_symbol = search_expression_type->get_type(MX_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18654
							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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18655
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18656
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18657
							{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18658
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18659
								symbol_c * return_type_symbol = IN_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18660
								s4o.print("__limit_");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18661
								IN_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18662
								s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18663
								MN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18664
								s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18665
								IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18666
								s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18667
								MX_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18668
								s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18669
								return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18670
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18671
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18672
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18673
							ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18674
						}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18675
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18676
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18677
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18678
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18679
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18680
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18681
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18682
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18683
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18684
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18685
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18686
	}/*function_limit*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18687
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18688
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18689
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18690
 *MUX
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18691
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18692
	case function_mux :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18693
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18694
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18695
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18696
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18697
			identifier_c param_name("K");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18698
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18699
			symbol_c *K_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18700
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18701
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18702
			if (K_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18703
			  K_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18704
			symbol_c *K_type_symbol = search_expression_type->get_type(K_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18705
			last_type_symbol = last_type_symbol && search_expression_type->is_same_type(K_type_symbol, last_type_symbol) ? search_expression_type->common_type(K_type_symbol, last_type_symbol) : K_type_symbol ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18706
			
34
a793b010e371 new generated files
lbessard
parents: 33
diff changeset
 18707
			if(search_expression_type->is_integer_type(K_type_symbol))
33
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18708
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18709
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18710
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18711
					identifier_c param_name("IN0");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18712
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18713
					symbol_c *IN0_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18714
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18715
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18716
					if (IN0_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18717
					  IN0_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18718
					symbol_c *IN0_type_symbol = search_expression_type->get_type(IN0_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18719
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18720
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18721
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18722
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18723
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18724
						{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18725
							identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18726
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18727
							symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18728
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18729
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18730
							if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18731
							  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18732
							symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18733
							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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18734
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18735
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18736
							{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18737
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18738
								symbol_c * return_type_symbol = last_type_symbol;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18739
								s4o.print("__mux_");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18740
								return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18741
								s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18742
								s4o.print_integer(nb_param);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18743
								s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18744
								K_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18745
								s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18746
								IN0_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18747
								s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18748
								IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18749
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18750
								int base_num = 2;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18751
								symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18752
								do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18753
									char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18754
									sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18755
									identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18756
									
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18757
									/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18758
									param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18759
									
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18760
									/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18761
									if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18762
									  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18763
									if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18764
										symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18765
										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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18766
									
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18767
										/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18768
										s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18769
										param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18770
										
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18771
									}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18772
									
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18773
								}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18774
								s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18775
								return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18776
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18777
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18778
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18779
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18780
							ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18781
						}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18782
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18783
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18784
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18785
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18786
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18787
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18788
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18789
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18790
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18791
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18792
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18793
	}/*function_mux*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18794
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18795
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18796
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18797
 *GT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18798
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18799
	case function_gt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18800
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18801
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18802
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18803
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18804
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18805
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18806
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18807
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18808
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18809
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18810
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18811
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18812
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18813
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18814
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18815
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18816
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18817
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18818
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18819
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18820
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18821
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18822
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18823
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18824
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18825
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18826
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18827
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18828
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18829
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18830
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18831
						symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18832
						s4o.print("__gt_");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18833
						return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18834
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18835
						s4o.print_integer(nb_param);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18836
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18837
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18838
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18839
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18840
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18841
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18842
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18843
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18844
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18845
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18846
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18847
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18848
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18849
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18850
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18851
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18852
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18853
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18854
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18855
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18856
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18857
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18858
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18859
								s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18860
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18861
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18862
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18863
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18864
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18865
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18866
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18867
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18868
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18869
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18870
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18871
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18872
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18873
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18874
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18875
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18876
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18877
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18878
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18879
	}/*function_gt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18880
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18881
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18882
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18883
 *GE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18884
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18885
	case function_ge :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18886
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18887
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18888
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18889
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18890
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18891
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18892
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18893
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18894
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18895
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18896
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18897
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18898
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18899
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18900
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18901
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18902
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18903
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18904
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18905
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18906
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18907
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18908
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18909
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18910
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18911
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18912
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18913
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18914
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18915
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18916
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18917
						symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18918
						s4o.print("__ge_");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18919
						return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18920
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18921
						s4o.print_integer(nb_param);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18922
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18923
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18924
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18925
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18926
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18927
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18928
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18929
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18930
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18931
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18932
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18933
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18934
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18935
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18936
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18937
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18938
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18939
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18940
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18941
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18942
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18943
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18944
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18945
								s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18946
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18947
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18948
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18949
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18950
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18951
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18952
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18953
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18954
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18955
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18956
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18957
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18958
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18959
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18960
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18961
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18962
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18963
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18964
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18965
	}/*function_ge*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18966
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18967
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18968
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18969
 *EQ
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18970
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18971
	case function_eq :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18972
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18973
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18974
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18975
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18976
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18977
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18978
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18979
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18980
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18981
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18982
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18983
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18984
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18985
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18986
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18987
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18988
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18989
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18990
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18991
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18992
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18993
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18994
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18995
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18996
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18997
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18998
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 18999
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19000
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19001
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19002
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19003
						symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19004
						s4o.print("__eq_");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19005
						return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19006
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19007
						s4o.print_integer(nb_param);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19008
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19009
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19010
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19011
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19012
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19013
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19014
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19015
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19016
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19017
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19018
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19019
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19020
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19021
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19022
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19023
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19024
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19025
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19026
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19027
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19028
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19029
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19030
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19031
								s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19032
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19033
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19034
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19035
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19036
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19037
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19038
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19039
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19040
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19041
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19042
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19043
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19044
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19045
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19046
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19047
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19048
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19049
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19050
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19051
	}/*function_eq*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19052
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19053
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19054
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19055
 *LT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19056
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19057
	case function_lt :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19058
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19059
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19060
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19061
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19062
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19063
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19064
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19065
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19066
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19067
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19068
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19069
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19070
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19071
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19072
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19073
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19074
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19075
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19076
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19077
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19078
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19079
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19080
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19081
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19082
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19083
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19084
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19085
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19086
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19087
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19088
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19089
						symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19090
						s4o.print("__lt_");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19091
						return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19092
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19093
						s4o.print_integer(nb_param);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19094
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19095
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19096
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19097
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19098
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19099
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19100
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19101
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19102
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19103
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19104
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19105
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19106
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19107
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19108
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19109
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19110
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19111
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19112
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19113
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19114
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19115
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19116
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19117
								s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19118
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19119
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19120
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19121
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19122
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19123
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19124
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19125
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19126
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19127
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19128
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19129
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19130
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19131
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19132
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19133
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19134
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19135
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19136
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19137
	}/*function_lt*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19138
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19139
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19140
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19141
 *LE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19142
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19143
	case function_le :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19144
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19145
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19146
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19147
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19148
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19149
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19150
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19151
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19152
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19153
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19154
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19155
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19156
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19157
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19158
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19159
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19160
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19161
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19162
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19163
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19164
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19165
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19166
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19167
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19168
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19169
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19170
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19171
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19172
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19173
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19174
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19175
						symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19176
						s4o.print("__le_");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19177
						return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19178
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19179
						s4o.print_integer(nb_param);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19180
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19181
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19182
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19183
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19184
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19185
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19186
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19187
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19188
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19189
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19190
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19191
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19192
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19193
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19194
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19195
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19196
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19197
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19198
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19199
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19200
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19201
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19202
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19203
								s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19204
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19205
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19206
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19207
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19208
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19209
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19210
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19211
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19212
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19213
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19214
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19215
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19216
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19217
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19218
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19219
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19220
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19221
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19222
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19223
	}/*function_le*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19224
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19225
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19226
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19227
 *NE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19228
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19229
	case function_ne :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19230
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19231
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19232
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19233
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19234
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19235
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19236
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19237
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19238
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19239
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19240
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19241
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19242
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19243
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19244
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19245
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19246
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19247
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19248
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19249
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19250
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19251
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19252
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19253
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19254
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19255
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19256
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19257
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19258
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19259
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19260
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19261
						symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19262
						s4o.print("__ne_");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19263
						return_type_symbol->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19264
						s4o.print("(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19265
						s4o.print_integer(nb_param);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19266
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19267
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19268
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19269
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19270
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19271
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19272
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19273
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19274
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19275
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19276
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19277
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19278
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19279
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19280
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19281
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19282
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19283
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19284
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19285
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19286
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19287
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19288
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19289
								s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19290
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19291
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19292
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19293
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19294
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19295
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19296
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19297
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19298
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19299
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19300
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19301
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19302
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19303
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19304
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19305
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19306
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19307
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19308
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19309
	}/*function_ne*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19310
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19311
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19312
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19313
 *LEN
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19314
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19315
	case function_len :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19316
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19317
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19318
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19319
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19320
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19321
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19322
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19323
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19324
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19325
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19326
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19327
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19328
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19329
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19330
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19331
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19332
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19333
				symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19334
				s4o.print("__len(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19335
				IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19336
				s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19337
				return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19338
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19339
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19340
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19341
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19342
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19343
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19344
	}/*function_len*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19345
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19346
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19347
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19348
 *LEFT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19349
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19350
	case function_left :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19351
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19352
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19353
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19354
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19355
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19356
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19357
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19358
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19359
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19360
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19361
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19362
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19363
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19364
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19365
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19366
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19367
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19368
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19369
					identifier_c param_name("L");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19370
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19371
					symbol_c *L_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19372
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19373
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19374
					if (L_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19375
					  L_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19376
					symbol_c *L_type_symbol = search_expression_type->get_type(L_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19377
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19378
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19379
					if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19380
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19381
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19382
						symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19383
						s4o.print("__left(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19384
						IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19385
						s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19386
						L_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19387
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19388
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19389
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19390
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19391
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19392
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19393
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19394
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19395
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19396
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19397
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19398
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19399
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19400
	}/*function_left*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19401
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19402
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19403
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19404
 *RIGHT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19405
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19406
	case function_right :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19407
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19408
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19409
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19410
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19411
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19412
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19413
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19414
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19415
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19416
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19417
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19418
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19419
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19420
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19421
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19422
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19423
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19424
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19425
					identifier_c param_name("L");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19426
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19427
					symbol_c *L_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19428
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19429
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19430
					if (L_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19431
					  L_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19432
					symbol_c *L_type_symbol = search_expression_type->get_type(L_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19433
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19434
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19435
					if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19436
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19437
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19438
						symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19439
						s4o.print("__right(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19440
						IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19441
						s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19442
						L_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19443
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19444
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19445
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19446
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19447
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19448
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19449
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19450
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19451
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19452
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19453
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19454
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19455
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19456
	}/*function_right*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19457
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19458
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19459
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19460
 *MID
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19461
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19462
	case function_mid :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19463
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19464
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19465
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19466
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19467
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19468
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19469
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19470
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19471
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19472
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19473
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19474
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19475
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19476
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19477
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19478
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19479
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19480
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19481
					identifier_c param_name("L");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19482
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19483
					symbol_c *L_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19484
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19485
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19486
					if (L_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19487
					  L_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19488
					symbol_c *L_type_symbol = search_expression_type->get_type(L_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19489
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19490
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19491
					if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19492
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19493
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19494
						{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19495
							identifier_c param_name("P");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19496
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19497
							symbol_c *P_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19498
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19499
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19500
							if (P_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19501
							  P_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19502
							symbol_c *P_type_symbol = search_expression_type->get_type(P_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19503
							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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19504
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19505
							if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19506
							{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19507
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19508
								symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19509
								s4o.print("__mid(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19510
								IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19511
								s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19512
								L_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19513
								s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19514
								P_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19515
								s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19516
								return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19517
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19518
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19519
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19520
							ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19521
						}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19522
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19523
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19524
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19525
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19526
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19527
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19528
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19529
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19530
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19531
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19532
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19533
	}/*function_mid*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19534
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19535
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19536
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19537
 *CONCAT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19538
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19539
	case function_concat :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19540
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19541
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19542
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19543
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19544
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19545
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19546
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19547
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19548
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19549
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19550
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19551
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19552
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19553
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19554
			if (typeid(*last_type_symbol) == typeid(date_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19555
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19556
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19557
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19558
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19559
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19560
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19561
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19562
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19563
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19564
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19565
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19566
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19567
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19568
					if (typeid(*last_type_symbol) == typeid(tod_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19569
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19570
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19571
						symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19572
						s4o.print("__time_add(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19573
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19574
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19575
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19576
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19577
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19578
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19579
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19580
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19581
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19582
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19583
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19584
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19585
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19586
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19587
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19588
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19589
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19590
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19591
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19592
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19593
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19594
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19595
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19596
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19597
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19598
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19599
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19600
					if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19601
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19602
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19603
						symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19604
						s4o.print("__concat(");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19605
						s4o.print_integer(nb_param);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19606
						s4o.print(",");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19607
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19608
						s4o.print(",&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19609
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19610
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19611
						int base_num = 3;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19612
						symbol_c *param_value = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19613
						do{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19614
							char my_name[10];
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19615
							sprintf(my_name, "IN%d", base_num++);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19616
							identifier_c param_name(my_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19617
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19618
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19619
							param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19620
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19621
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19622
							if (param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19623
							  param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19624
							if (param_value != NULL){
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19625
								symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19626
								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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19627
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19628
								/*Function specific CODE */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19629
								s4o.print(",&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19630
								param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19631
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19632
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19633
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19634
						}while(param_value != NULL);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19635
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19636
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19637
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19638
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19639
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19640
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19641
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19642
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19643
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19644
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19645
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19646
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19647
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19648
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19649
	}/*function_concat*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19650
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19651
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19652
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19653
 *INSERT
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19654
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19655
	case function_insert :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19656
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19657
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19658
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19659
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19660
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19661
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19662
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19663
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19664
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19665
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19666
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19667
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19668
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19669
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19670
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19671
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19672
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19673
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19674
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19675
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19676
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19677
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19678
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19679
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19680
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19681
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19682
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19683
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19684
					if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19685
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19686
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19687
						{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19688
							identifier_c param_name("P");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19689
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19690
							symbol_c *P_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19691
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19692
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19693
							if (P_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19694
							  P_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19695
							symbol_c *P_type_symbol = search_expression_type->get_type(P_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19696
							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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19697
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19698
							if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19699
							{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19700
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19701
								symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19702
								s4o.print("__insert(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19703
								IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19704
								s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19705
								IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19706
								s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19707
								P_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19708
								s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19709
								return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19710
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19711
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19712
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19713
							ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19714
						}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19715
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19716
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19717
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19718
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19719
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19720
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19721
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19722
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19723
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19724
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19725
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19726
	}/*function_insert*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19727
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19728
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19729
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19730
 *DELETE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19731
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19732
	case function_delete :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19733
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19734
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19735
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19736
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19737
			identifier_c param_name("IN");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19738
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19739
			symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19740
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19741
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19742
			if (IN_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19743
			  IN_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19744
			symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19745
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19746
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19747
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19748
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19749
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19750
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19751
					identifier_c param_name("L");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19752
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19753
					symbol_c *L_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19754
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19755
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19756
					if (L_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19757
					  L_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19758
					symbol_c *L_type_symbol = search_expression_type->get_type(L_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19759
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19760
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19761
					if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19762
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19763
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19764
						{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19765
							identifier_c param_name("P");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19766
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19767
							symbol_c *P_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19768
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19769
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19770
							if (P_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19771
							  P_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19772
							symbol_c *P_type_symbol = search_expression_type->get_type(P_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19773
							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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19774
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19775
							if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19776
							{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19777
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19778
								symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19779
								s4o.print("__delete(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19780
								IN_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19781
								s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19782
								L_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19783
								s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19784
								P_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19785
								s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19786
								return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19787
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19788
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19789
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19790
							ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19791
						}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19792
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19793
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19794
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19795
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19796
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19797
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19798
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19799
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19800
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19801
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19802
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19803
	}/*function_delete*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19804
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19805
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19806
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19807
 *REPLACE
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19808
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19809
	case function_replace :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19810
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19811
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19812
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19813
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19814
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19815
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19816
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19817
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19818
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19819
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19820
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19821
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19822
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19823
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19824
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19825
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19826
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19827
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19828
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19829
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19830
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19831
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19832
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19833
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19834
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19835
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19836
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19837
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19838
					if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19839
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19840
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19841
						{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19842
							identifier_c param_name("L");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19843
							/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19844
							symbol_c *L_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19845
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19846
							/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19847
							if (L_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19848
							  L_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19849
							symbol_c *L_type_symbol = search_expression_type->get_type(L_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19850
							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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19851
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19852
							if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19853
							{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19854
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19855
								{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19856
									identifier_c param_name("P");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19857
									/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19858
									symbol_c *P_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19859
									
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19860
									/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19861
									if (P_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19862
									  P_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19863
									symbol_c *P_type_symbol = search_expression_type->get_type(P_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19864
									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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19865
									
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19866
									if (typeid(*last_type_symbol) == typeid(uint_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19867
									{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19868
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19869
										symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19870
										s4o.print("__replace(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19871
										IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19872
										s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19873
										IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19874
										s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19875
										L_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19876
										s4o.print(", ");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19877
										P_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19878
										s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19879
										return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19880
										
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19881
									}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19882
									
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19883
									ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19884
								}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19885
								
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19886
							}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19887
							
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19888
							ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19889
						}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19890
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19891
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19892
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19893
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19894
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19895
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19896
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19897
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19898
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19899
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19900
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19901
	}/*function_replace*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19902
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19903
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19904
/****
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19905
 *FIND
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19906
 */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19907
	case function_find :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19908
	{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19909
		symbol_c *last_type_symbol = NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19910
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19911
		{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19912
			identifier_c param_name("IN1");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19913
			/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19914
			symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19915
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19916
			/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19917
			if (IN1_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19918
			  IN1_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19919
			symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19920
			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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19921
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19922
			if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19923
			{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19924
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19925
				{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19926
					identifier_c param_name("IN2");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19927
					/* Get the value from a foo(<param_name> = <param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19928
					symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19929
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19930
					/* Get the value from a foo(<param_value>) style call */
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19931
					if (IN2_param_value == NULL)
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19932
					  IN2_param_value = function_call_param_iterator.next();
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19933
					symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19934
					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 ;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19935
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19936
					if (typeid(*last_type_symbol) == typeid(string_type_name_c))
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19937
					{
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19938
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19939
						symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19940
						s4o.print("__find(&");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19941
						IN1_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19942
						s4o.print(", &");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19943
						IN2_param_value->accept(*this);
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19944
						s4o.print(")");
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19945
						return NULL;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19946
						
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19947
					}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19948
					
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19949
					ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19950
				}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19951
				
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19952
			}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19953
			
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19954
			ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19955
		}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19956
		
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19957
	}/*function_find*/
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19958
	break;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19959
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19960
	case function_none :
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19961
	ERROR;
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19962
}
4507beb2aac6 preliminary std lib support for ST
etisserant
parents:
diff changeset
 19963
return NULL;