штуку
char *all_command_list()
{
log_it(L_DEBUG, "Get all commands for autocomplete");
char *tmp = DAP_NEW_SIZE(char, 32 * sizeof (char));;
char *last_str = NULL;
dap_chain_node_cmd_item_t *l_cmd = dap_chain_node_cli_cmd_get_first();
while(l_cmd) {
*tmp = *last_str;
last_str = DAP_NEW_SIZE(char, (strlen(tmp) + 32) * sizeof (char));
dap_snprintf(last_str, (strlen(tmp) + 32), "%s%s", tmp, l_cmd->name);
log_it(L_DEBUG, "\n\n\n\n\n\n\n\n\n%s\n\n\n\n\n\n\n\n\n", l_cmd->name);
l_cmd = (dap_chain_node_cmd_item_t*) l_cmd->hh.next;
}
return last_str;
}
не уверена в этой строке *tmp = *last_str;. по сути мне просто в буффер надо надо временное значение положить, чтобы по указателю не затерлось, когда буду указатель last_str переделывать. это так работает или не очень?)
вы нулевой указатель разыменовываете
ага, при первой итерации. проверка на нул, плюс каждый раз tmp под нужный размер маллочить еще...
проблема-то в чём?
в днк) просто немного с указателях и памти запуталась)
На первой итерации, да, возможно.
Обсуждают сегодня