Create content_ctl

This commit is contained in:
twinaphex 2016-01-19 22:12:25 +01:00
parent 8702689aaa
commit 2836c9755a
3 changed files with 35 additions and 22 deletions

View File

@ -1482,7 +1482,7 @@ bool event_command(enum event_command cmd)
input_driver_ctl(RARCH_INPUT_CTL_REMOTE_INIT, NULL); input_driver_ctl(RARCH_INPUT_CTL_REMOTE_INIT, NULL);
break; break;
case EVENT_CMD_TEMPORARY_CONTENT_DEINIT: case EVENT_CMD_TEMPORARY_CONTENT_DEINIT:
content_temporary_free(); content_ctl(CONTENT_CTL_TEMPORARY_FREE, NULL);
break; break;
case EVENT_CMD_SUBSYSTEM_FULLPATHS_DEINIT: case EVENT_CMD_SUBSYSTEM_FULLPATHS_DEINIT:
if (!global) if (!global)

View File

@ -750,21 +750,19 @@ bool init_content_file(void)
error: error:
if (content) if (content)
string_list_free(content); string_list_free(content);
content_temporary_free(); content_ctl(CONTENT_CTL_TEMPORARY_FREE, NULL);
return false; return false;
} }
/** bool content_ctl(enum content_ctl_state state, void *data)
* content_free_temporary:
*
* Frees temporary content handle.
**/
void content_temporary_free(void)
{ {
unsigned i; unsigned i;
switch(state)
{
case CONTENT_CTL_TEMPORARY_FREE:
if (!temporary_content) if (!temporary_content)
return; return false;
for (i = 0; i < temporary_content->size; i++) for (i = 0; i < temporary_content->size; i++)
{ {
@ -780,4 +778,11 @@ void content_temporary_free(void)
string_list_free(temporary_content); string_list_free(temporary_content);
temporary_content = NULL; temporary_content = NULL;
break;
case CONTENT_CTL_NONE:
default:
break;
}
return true;
} }

View File

@ -27,6 +27,14 @@
extern "C" { extern "C" {
#endif #endif
enum content_ctl_state
{
CONTENT_CTL_NONE = 0,
/* Frees temporary content handle. */
CONTENT_CTL_TEMPORARY_FREE
};
/* Handles files related to libretro. */ /* Handles files related to libretro. */
/** /**
@ -83,7 +91,7 @@ void save_ram_file(const char *path, int type);
**/ **/
bool init_content_file(void); bool init_content_file(void);
void content_temporary_free(void); bool content_ctl(enum content_ctl_state state, void *data);
#ifdef __cplusplus #ifdef __cplusplus
} }