core_info.c - Refactor
This commit is contained in:
parent
15713a1bfa
commit
91cf0508fe
61
core_info.c
61
core_info.c
|
@ -71,11 +71,12 @@ static void core_info_list_resolve_all_firmware(
|
||||||
{
|
{
|
||||||
unsigned count = 0;
|
unsigned count = 0;
|
||||||
core_info_t *info = (core_info_t*)&core_info_list->list[i];
|
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;
|
continue;
|
||||||
|
|
||||||
if (!config_get_uint(info->data, "firmware_count", &count))
|
if (!config_get_uint(config, "firmware_count", &count))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
info->firmware = (core_info_firmware_t*)
|
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(desc_key, sizeof(desc_key), "firmware%u_desc", c);
|
||||||
snprintf(opt_key, sizeof(opt_key), "firmware%u_opt", 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(config, path_key, &info->firmware[c].path);
|
||||||
config_get_string(info->data, desc_key, &info->firmware[c].desc);
|
config_get_string(config, desc_key, &info->firmware[c].desc);
|
||||||
config_get_bool(info->data, opt_key , &info->firmware[c].optional);
|
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++)
|
for (i = 0; i < contents->size; i++)
|
||||||
{
|
{
|
||||||
|
config_file_t *conf = NULL;
|
||||||
char info_path_base[PATH_MAX_LENGTH] = {0};
|
char info_path_base[PATH_MAX_LENGTH] = {0};
|
||||||
char info_path[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,
|
settings->libretro_info_path : settings->libretro_directory,
|
||||||
info_path_base, sizeof(info_path));
|
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)
|
||||||
config_get_string(core_info[i].data, "corename",
|
{
|
||||||
|
config_get_string(conf, "corename",
|
||||||
&core_info[i].core_name);
|
&core_info[i].core_name);
|
||||||
|
core_info[i].config_data = (void*)conf;
|
||||||
|
}
|
||||||
|
|
||||||
strlcpy(s, core_info[i].core_name, len);
|
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++)
|
for (i = 0; i < contents->size; i++)
|
||||||
{
|
{
|
||||||
|
config_file_t *conf = NULL;
|
||||||
char info_path_base[PATH_MAX_LENGTH] = {0};
|
char info_path_base[PATH_MAX_LENGTH] = {0};
|
||||||
char info_path[PATH_MAX_LENGTH] = {0};
|
char info_path[PATH_MAX_LENGTH] = {0};
|
||||||
core_info[i].path = strdup(contents->elems[i].data);
|
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,
|
settings->libretro_info_path : settings->libretro_directory,
|
||||||
info_path_base, sizeof(info_path));
|
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;
|
unsigned count = 0;
|
||||||
config_get_string(core_info[i].data, "display_name",
|
config_get_string(conf, "display_name",
|
||||||
&core_info[i].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);
|
&core_info[i].core_name);
|
||||||
config_get_string(core_info[i].data, "systemname",
|
config_get_string(conf, "systemname",
|
||||||
&core_info[i].systemname);
|
&core_info[i].systemname);
|
||||||
config_get_string(core_info[i].data, "manufacturer",
|
config_get_string(conf, "manufacturer",
|
||||||
&core_info[i].system_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;
|
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)
|
core_info[i].supported_extensions)
|
||||||
core_info[i].supported_extensions_list =
|
core_info[i].supported_extensions_list =
|
||||||
string_split(core_info[i].supported_extensions, "|");
|
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)
|
core_info[i].authors)
|
||||||
core_info[i].authors_list =
|
core_info[i].authors_list =
|
||||||
string_split(core_info[i].authors, "|");
|
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)
|
core_info[i].permissions)
|
||||||
core_info[i].permissions_list =
|
core_info[i].permissions_list =
|
||||||
string_split(core_info[i].permissions, "|");
|
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)
|
core_info[i].licenses)
|
||||||
core_info[i].licenses_list =
|
core_info[i].licenses_list =
|
||||||
string_split(core_info[i].licenses, "|");
|
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)
|
core_info[i].categories)
|
||||||
core_info[i].categories_list =
|
core_info[i].categories_list =
|
||||||
string_split(core_info[i].categories, "|");
|
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)
|
core_info[i].databases)
|
||||||
core_info[i].databases_list =
|
core_info[i].databases_list =
|
||||||
string_split(core_info[i].databases, "|");
|
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].notes)
|
core_info[i].notes)
|
||||||
core_info[i].note_list = string_split(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].supports_no_game);
|
||||||
|
|
||||||
|
core_info[i].config_data = conf;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!core_info[i].display_name)
|
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->licenses_list);
|
||||||
string_list_free(info->categories_list);
|
string_list_free(info->categories_list);
|
||||||
string_list_free(info->databases_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++)
|
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;
|
return 0;
|
||||||
|
|
||||||
for (i = 0; i < core_info_list->count; i++)
|
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;
|
return num;
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,6 @@
|
||||||
#ifndef CORE_INFO_H_
|
#ifndef CORE_INFO_H_
|
||||||
#define CORE_INFO_H_
|
#define CORE_INFO_H_
|
||||||
|
|
||||||
#include <file/config_file.h>
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -38,7 +37,7 @@ typedef struct
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
char *path;
|
char *path;
|
||||||
config_file_t *data;
|
void *config_data;
|
||||||
char *display_name;
|
char *display_name;
|
||||||
char *core_name;
|
char *core_name;
|
||||||
char *system_manufacturer;
|
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();
|
global_t *global = global_get_ptr();
|
||||||
core_info_t *core_info = global ? (core_info_t*)global->core_info.current : NULL;
|
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_entries_push(info->list,
|
||||||
menu_hash_to_str(MENU_LABEL_VALUE_NO_CORE_INFORMATION_AVAILABLE),
|
menu_hash_to_str(MENU_LABEL_VALUE_NO_CORE_INFORMATION_AVAILABLE),
|
||||||
|
|
Loading…
Reference in New Issue