finish task if state file cannot be loaded

This commit is contained in:
Brad Parker 2016-10-02 19:31:07 -04:00
parent 795fd0cfa3
commit 06f06d512b

View File

@ -650,6 +650,7 @@ static void task_load_handler_finished(retro_task_t *task,
load_task_data_t *task_data = NULL; load_task_data_t *task_data = NULL;
task->finished = true; task->finished = true;
if (state->file)
filestream_close(state->file); filestream_close(state->file);
if (!task->error && task->cancelled) if (!task->error && task->cancelled)
@ -680,22 +681,22 @@ static void task_load_handler(retro_task_t *task)
state->file = filestream_open(state->path, RFILE_MODE_READ, -1); state->file = filestream_open(state->path, RFILE_MODE_READ, -1);
if (!state->file) if (!state->file)
return; goto error;
if (filestream_seek(state->file, 0, SEEK_END) != 0) if (filestream_seek(state->file, 0, SEEK_END) != 0)
return; goto error;
state->size = filestream_tell(state->file); state->size = filestream_tell(state->file);
if (state->size < 0) if (state->size < 0)
return; goto error;
filestream_rewind(state->file); filestream_rewind(state->file);
state->data = malloc(state->size + 1); state->data = malloc(state->size + 1);
if (!state->data) if (!state->data)
return; goto error;
} }
remaining = MIN(state->size - state->bytes_read, SAVE_STATE_CHUNK); remaining = MIN(state->size - state->bytes_read, SAVE_STATE_CHUNK);
@ -757,6 +758,11 @@ static void task_load_handler(retro_task_t *task)
return; return;
} }
return;
error:
task_load_handler_finished(task, state);
} }
/** /**