1
0
mirror of https://github.com/mpv-player/mpv synced 2025-01-02 13:02:24 +00:00

input.c: Use talloc for command bind allocations

This commit is contained in:
Uoti Urpala 2008-04-30 10:06:45 +03:00
parent d0e8292629
commit f7879d206e

View File

@ -1017,14 +1017,14 @@ static mp_cmd_bind_section_t *get_bind_section(struct input_ctx *ictx,
bind_section=bind_section->next;
}
if(bind_section) {
bind_section->next=malloc(sizeof(mp_cmd_bind_section_t));
bind_section->next = talloc_ptrtype(ictx, bind_section->next);
bind_section=bind_section->next;
} else {
ictx->cmd_bind_sections = malloc(sizeof(mp_cmd_bind_section_t));
ictx->cmd_bind_sections = talloc_ptrtype(ictx, ictx->cmd_bind_sections);
bind_section = ictx->cmd_bind_sections;
}
bind_section->cmd_binds=NULL;
bind_section->section=strdup(section);
bind_section->section = talloc_strdup(bind_section, section);
bind_section->next=NULL;
return bind_section;
}
@ -1480,13 +1480,15 @@ static void bind_keys(struct input_ctx *ictx,
}
if(!bind) {
bind_section->cmd_binds = realloc(bind_section->cmd_binds,(i+2)*sizeof(mp_cmd_bind_t));
bind_section->cmd_binds = talloc_realloc(bind_section,
bind_section->cmd_binds,
mp_cmd_bind_t, i + 2);
memset(&bind_section->cmd_binds[i],0,2*sizeof(mp_cmd_bind_t));
bind = &bind_section->cmd_binds[i];
}
if(bind->cmd)
free(bind->cmd);
bind->cmd = strdup(cmd);
talloc_free(bind->cmd);
bind->cmd = talloc_strdup(bind_section->cmd_binds, cmd);
memcpy(bind->input,keys,(MP_MAX_KEY_DOWN+1)*sizeof(int));
}
@ -1497,20 +1499,6 @@ static void add_binds(struct input_ctx *ictx, const mp_cmd_bind_t* list)
bind_keys(ictx, list[i].input,list[i].cmd);
}
static void free_binds(mp_cmd_bind_t* binds)
{
int i;
if(!binds)
return;
for(i = 0; binds[i].cmd != NULL; i++)
free(binds[i].cmd);
free(binds);
}
static int parse_config(struct input_ctx *ictx, char *file)
{
int fd;
@ -1669,11 +1657,11 @@ void mp_input_set_section(struct input_ctx *ictx, char *name)
ictx->cmd_binds = NULL;
ictx->cmd_binds_default = NULL;
if (ictx->section)
free(ictx->section);
talloc_free(ictx->section);
if (name)
ictx->section = strdup(name);
ictx->section = talloc_strdup(ictx, name);
else
ictx->section = strdup("default");
ictx->section = talloc_strdup(ictx, "default");
if ((bind_section = get_bind_section(ictx, ictx->section)))
ictx->cmd_binds = bind_section->cmd_binds;
if (strcmp(ictx->section, "default") == 0)
@ -1780,7 +1768,6 @@ void mp_input_uninit(struct input_ctx *ictx)
return;
unsigned int i;
mp_cmd_bind_section_t* bind_section;
for(i=0; i < num_key_fd; i++) {
if(key_fds[i].close_func)
@ -1791,13 +1778,6 @@ void mp_input_uninit(struct input_ctx *ictx)
if(cmd_fds[i].close_func)
cmd_fds[i].close_func(cmd_fds[i].fd);
}
while (ictx->cmd_bind_sections) {
free_binds(ictx->cmd_bind_sections->cmd_binds);
free(ictx->cmd_bind_sections->section);
bind_section=ictx->cmd_bind_sections->next;
free(ictx->cmd_bind_sections);
ictx->cmd_bind_sections=bind_section;
}
talloc_free(ictx);
}