self->argc = NULL;
self->fixedparams = NULL;
self->return_value = NULL;
-
- self->static_names = NULL;
self->static_count = 0;
return self;
void ast_function_delete(ast_function *self)
{
- size_t i;
if (self->name)
mem_d((void*)self->name);
if (self->vtype) {
*/
ast_unref(self->vtype);
}
- for (i = 0; i < vec_size(self->static_names); ++i)
- mem_d(self->static_names[i]);
- vec_free(self->static_names);
+ for (auto &it : self->static_names)
+ mem_d(it);
for (auto &it : self->blocks)
ast_delete(it);
if (self->varargs)
bool ast_call_codegen(ast_call *self, ast_function *func, bool lvalue, ir_value **out)
{
ast_expression_codegen *cgen;
- ir_value **params;
- ir_instr *callinstr;
- size_t i;
+ std::vector<ir_value*> params;
+ ir_instr *callinstr;
ir_value *funval = NULL;
if (!funval)
return false;
- params = NULL;
-
/* parameters */
for (auto &it : self->params) {
ir_value *param;
cgen = it->codegen;
if (!(*cgen)(it, func, false, ¶m))
- goto error;
+ return false;
if (!param)
- goto error;
- vec_push(params, param);
+ return false;
+ params.push_back(param);
}
/* varargs counter */
ast_function_label(func, "call"),
funval, !!(self->func->flags & AST_FLAG_NORETURN));
if (!callinstr)
- goto error;
+ return false;
- for (i = 0; i < vec_size(params); ++i) {
- ir_call_param(callinstr, params[i]);
- }
+ for (auto &it : params)
+ ir_call_param(callinstr, it);
*out = ir_call_value(callinstr);
self->expression.outr = *out;
codegen_output_type(self, *out);
- vec_free(params);
return true;
-error:
- vec_free(params);
- return false;
}
int builtin;
/* list of used-up names for statics without the count suffix */
- char **static_names;
+ std::vector<char*> static_names;
/* number of static variables, by convention this includes the
* ones without the count-suffix - remember this when dealing
* with savegames. uint instead of size_t as %zu in printf is
* counter value.
* The counter is incremented either way.
*/
- sn_size = vec_size(parser->function->static_names);
+ sn_size = parser->function->static_names.size();
for (sn = 0; sn != sn_size; ++sn) {
if (strcmp(parser->function->static_names[sn], var->name) == 0)
break;
mem_d(num);
}
else
- vec_push(parser->function->static_names, util_strdup(var->name));
+ parser->function->static_names.push_back(util_strdup(var->name));
parser->function->static_count++;
ast_value_set_name(var, defname);