static void local_variable_free(local_variable_t v)
{
- xbt_free(v->name);
- xbt_free(v);
+ delete(v);
}
static void local_variable_free_voidp(void *v)
else
region_type = 2;
- local_variable_t new_var = xbt_new0(s_local_variable_t, 1);
+ local_variable_t new_var = new s_local_variable_t();
new_var->subprogram = stack_frame->frame;
new_var->ip = stack_frame->ip;
- new_var->name = xbt_strdup(current_variable->name);
+ new_var->name = current_variable->name;
new_var->type = current_variable->type;
new_var->region = region_type;
current_var2 =
(local_variable_t) xbt_dynar_get_as(stack2->local_variables, cursor,
local_variable_t);
- if (strcmp(current_var1->name, current_var2->name) != 0
+ if (current_var1->name != current_var2->name
|| current_var1->subprogram != current_var1->subprogram
|| current_var1->ip != current_var2->ip) {
// TODO, fix current_varX->subprogram->name to include name if DW_TAG_inlined_subprogram
XBT_VERB
("Different name of variable (%s - %s) or frame (%s - %s) or ip (%lu - %lu)",
- current_var1->name, current_var2->name,
+ current_var1->name.c_str(), current_var2->name.c_str(),
current_var1->subprogram->name, current_var2->subprogram->name,
current_var1->ip, current_var2->ip);
return 1;
XBT_TRACE3(mc, local_diff, -1, -1, current_var1->name);
XBT_VERB
("Local variable %s (%p - %p) in frame %s is different between snapshots",
- current_var1->name, current_var1->address, current_var2->address,
+ current_var1->name.c_str(), current_var1->address, current_var2->address,
current_var1->subprogram->name);
return res;
}