mirror of
https://github.com/libretro/RetroArch.git
synced 2025-02-22 02:30:56 +00:00
core_info.c - Refactor
This commit is contained in:
parent
15713a1bfa
commit
91cf0508fe
65
core_info.c
65
core_info.c
@ -69,13 +69,14 @@ static void core_info_list_resolve_all_firmware(
|
||||
|
||||
for (i = 0; i < core_info_list->count; i++)
|
||||
{
|
||||
unsigned count = 0;
|
||||
core_info_t *info = (core_info_t*)&core_info_list->list[i];
|
||||
unsigned count = 0;
|
||||
core_info_t *info = (core_info_t*)&core_info_list->list[i];
|
||||
config_file_t *config = info->config_data;
|
||||
|
||||
if (!info || !info->data)
|
||||
if (!info || !config)
|
||||
continue;
|
||||
|
||||
if (!config_get_uint(info->data, "firmware_count", &count))
|
||||
if (!config_get_uint(config, "firmware_count", &count))
|
||||
continue;
|
||||
|
||||
info->firmware = (core_info_firmware_t*)
|
||||
@ -94,9 +95,9 @@ static void core_info_list_resolve_all_firmware(
|
||||
snprintf(desc_key, sizeof(desc_key), "firmware%u_desc", c);
|
||||
snprintf(opt_key, sizeof(opt_key), "firmware%u_opt", c);
|
||||
|
||||
config_get_string(info->data, path_key, &info->firmware[c].path);
|
||||
config_get_string(info->data, desc_key, &info->firmware[c].desc);
|
||||
config_get_bool(info->data, opt_key , &info->firmware[c].optional);
|
||||
config_get_string(config, path_key, &info->firmware[c].path);
|
||||
config_get_string(config, desc_key, &info->firmware[c].desc);
|
||||
config_get_bool(config, opt_key , &info->firmware[c].optional);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -125,6 +126,7 @@ void core_info_get_name(const char *path, char *s, size_t len)
|
||||
|
||||
for (i = 0; i < contents->size; i++)
|
||||
{
|
||||
config_file_t *conf = NULL;
|
||||
char info_path_base[PATH_MAX_LENGTH] = {0};
|
||||
char info_path[PATH_MAX_LENGTH] = {0};
|
||||
|
||||
@ -152,11 +154,14 @@ void core_info_get_name(const char *path, char *s, size_t len)
|
||||
settings->libretro_info_path : settings->libretro_directory,
|
||||
info_path_base, sizeof(info_path));
|
||||
|
||||
core_info[i].data = config_file_new(info_path);
|
||||
conf = config_file_new(info_path);
|
||||
|
||||
if (core_info[i].data)
|
||||
config_get_string(core_info[i].data, "corename",
|
||||
if (conf)
|
||||
{
|
||||
config_get_string(conf, "corename",
|
||||
&core_info[i].core_name);
|
||||
core_info[i].config_data = (void*)conf;
|
||||
}
|
||||
|
||||
strlcpy(s, core_info[i].core_name, len);
|
||||
}
|
||||
@ -192,6 +197,7 @@ core_info_list_t *core_info_list_new(void)
|
||||
|
||||
for (i = 0; i < contents->size; i++)
|
||||
{
|
||||
config_file_t *conf = NULL;
|
||||
char info_path_base[PATH_MAX_LENGTH] = {0};
|
||||
char info_path[PATH_MAX_LENGTH] = {0};
|
||||
core_info[i].path = strdup(contents->elems[i].data);
|
||||
@ -215,64 +221,66 @@ core_info_list_t *core_info_list_new(void)
|
||||
settings->libretro_info_path : settings->libretro_directory,
|
||||
info_path_base, sizeof(info_path));
|
||||
|
||||
core_info[i].data = config_file_new(info_path);
|
||||
conf = config_file_new(info_path);
|
||||
|
||||
if (core_info[i].data)
|
||||
if (conf)
|
||||
{
|
||||
unsigned count = 0;
|
||||
config_get_string(core_info[i].data, "display_name",
|
||||
config_get_string(conf, "display_name",
|
||||
&core_info[i].display_name);
|
||||
config_get_string(core_info[i].data, "corename",
|
||||
config_get_string(conf, "corename",
|
||||
&core_info[i].core_name);
|
||||
config_get_string(core_info[i].data, "systemname",
|
||||
config_get_string(conf, "systemname",
|
||||
&core_info[i].systemname);
|
||||
config_get_string(core_info[i].data, "manufacturer",
|
||||
config_get_string(conf, "manufacturer",
|
||||
&core_info[i].system_manufacturer);
|
||||
config_get_uint(core_info[i].data, "firmware_count", &count);
|
||||
config_get_uint(conf, "firmware_count", &count);
|
||||
core_info[i].firmware_count = count;
|
||||
if (config_get_string(core_info[i].data, "supported_extensions",
|
||||
if (config_get_string(conf, "supported_extensions",
|
||||
&core_info[i].supported_extensions) &&
|
||||
core_info[i].supported_extensions)
|
||||
core_info[i].supported_extensions_list =
|
||||
string_split(core_info[i].supported_extensions, "|");
|
||||
|
||||
if (config_get_string(core_info[i].data, "authors",
|
||||
if (config_get_string(conf, "authors",
|
||||
&core_info[i].authors) &&
|
||||
core_info[i].authors)
|
||||
core_info[i].authors_list =
|
||||
string_split(core_info[i].authors, "|");
|
||||
|
||||
if (config_get_string(core_info[i].data, "permissions",
|
||||
if (config_get_string(conf, "permissions",
|
||||
&core_info[i].permissions) &&
|
||||
core_info[i].permissions)
|
||||
core_info[i].permissions_list =
|
||||
string_split(core_info[i].permissions, "|");
|
||||
|
||||
if (config_get_string(core_info[i].data, "license",
|
||||
if (config_get_string(conf, "license",
|
||||
&core_info[i].licenses) &&
|
||||
core_info[i].licenses)
|
||||
core_info[i].licenses_list =
|
||||
string_split(core_info[i].licenses, "|");
|
||||
|
||||
if (config_get_string(core_info[i].data, "categories",
|
||||
if (config_get_string(conf, "categories",
|
||||
&core_info[i].categories) &&
|
||||
core_info[i].categories)
|
||||
core_info[i].categories_list =
|
||||
string_split(core_info[i].categories, "|");
|
||||
|
||||
if (config_get_string(core_info[i].data, "database",
|
||||
if (config_get_string(conf, "database",
|
||||
&core_info[i].databases) &&
|
||||
core_info[i].databases)
|
||||
core_info[i].databases_list =
|
||||
string_split(core_info[i].databases, "|");
|
||||
|
||||
if (config_get_string(core_info[i].data, "notes",
|
||||
if (config_get_string(conf, "notes",
|
||||
&core_info[i].notes) &&
|
||||
core_info[i].notes)
|
||||
core_info[i].note_list = string_split(core_info[i].notes, "|");
|
||||
|
||||
config_get_bool(core_info[i].data, "supports_no_game",
|
||||
config_get_bool(conf, "supports_no_game",
|
||||
&core_info[i].supports_no_game);
|
||||
|
||||
core_info[i].config_data = conf;
|
||||
}
|
||||
|
||||
if (!core_info[i].display_name)
|
||||
@ -326,7 +334,7 @@ void core_info_list_free(core_info_list_t *core_info_list)
|
||||
string_list_free(info->licenses_list);
|
||||
string_list_free(info->categories_list);
|
||||
string_list_free(info->databases_list);
|
||||
config_file_free(info->data);
|
||||
config_file_free((config_file_t*)info->config_data);
|
||||
|
||||
for (j = 0; j < info->firmware_count; j++)
|
||||
{
|
||||
@ -349,7 +357,10 @@ size_t core_info_list_num_info_files(core_info_list_t *core_info_list)
|
||||
return 0;
|
||||
|
||||
for (i = 0; i < core_info_list->count; i++)
|
||||
num += !!core_info_list->list[i].data;
|
||||
{
|
||||
config_file_t *conf = (config_file_t*)core_info_list->list[i].config_data;
|
||||
num += !!conf;
|
||||
}
|
||||
|
||||
return num;
|
||||
}
|
||||
|
@ -18,7 +18,6 @@
|
||||
#ifndef CORE_INFO_H_
|
||||
#define CORE_INFO_H_
|
||||
|
||||
#include <file/config_file.h>
|
||||
#include <stddef.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
@ -38,7 +37,7 @@ typedef struct
|
||||
typedef struct
|
||||
{
|
||||
char *path;
|
||||
config_file_t *data;
|
||||
void *config_data;
|
||||
char *display_name;
|
||||
char *core_name;
|
||||
char *system_manufacturer;
|
||||
|
@ -162,7 +162,7 @@ static int menu_displaylist_parse_core_info(menu_displaylist_info_t *info)
|
||||
global_t *global = global_get_ptr();
|
||||
core_info_t *core_info = global ? (core_info_t*)global->core_info.current : NULL;
|
||||
|
||||
if (!core_info || !core_info->data)
|
||||
if (!core_info || !core_info->config_data)
|
||||
{
|
||||
menu_entries_push(info->list,
|
||||
menu_hash_to_str(MENU_LABEL_VALUE_NO_CORE_INFORMATION_AVAILABLE),
|
||||
|
Loading…
x
Reference in New Issue
Block a user