Make languages default to english with missing data

This commit is contained in:
EmeraldLockdown 2026-03-11 19:34:19 -05:00
parent 8b4fadc89e
commit 14c12eb0e5
2 changed files with 23 additions and 9 deletions

View file

@ -7,33 +7,45 @@
#include "pc/djui/djui_language.h" #include "pc/djui/djui_language.h"
#include "pc/djui/djui_popup.h" #include "pc/djui/djui_popup.h"
static ini_t* sEnglishLang = NULL;
static ini_t* sLang = NULL; static ini_t* sLang = NULL;
bool djui_language_init(char* lang) { bool djui_language_init(char* lang) {
// free old ini // free old ini
if (sLang != NULL) { ini_free(sLang);
ini_free(sLang); sLang = NULL;
sLang = NULL; ini_free(sEnglishLang);
} sEnglishLang = NULL;
// construct path // construct path
char path[SYS_MAX_PATH] = ""; char path[SYS_MAX_PATH] = "";
if (!lang || lang[0] == '\0') { lang = "English"; } if (!lang || lang[0] == '\0') { lang = "English"; }
snprintf(path, SYS_MAX_PATH, "%s/lang/%s.ini", sys_resource_path(), lang); snprintf(path, SYS_MAX_PATH, "%s/lang/%s.ini", sys_resource_path(), lang);
// load // load normal lang
sLang = ini_load(path); sLang = ini_load(path);
// load english lang
snprintf(path, SYS_MAX_PATH, "%s/lang/English.ini", sys_resource_path());
sEnglishLang = ini_load(path);
return sLang != NULL; return sLang != NULL;
} }
char* djui_language_get(const char *section, const char *key) { static char* djui_language_get_english(const char *section, const char *key) {
if (!sLang) { return (char*)key; } if (!sEnglishLang) { return (char*)key; }
char* value = (char*)ini_get(sLang, section, key); char* value = (char*)ini_get(sEnglishLang, section, key);
if (!value) { return (char*)key; } if (!value) { return (char*)key; }
return value; return value;
} }
char* djui_language_get(const char *section, const char *key) {
if (!sLang) { return djui_language_get_english(section, key); }
char* value = (char*)ini_get(sLang, section, key);
if (!value) { return djui_language_get_english(section, key); }
return value;
}
char* djui_language_find_key(const char* section, const char* value) { char* djui_language_find_key(const char* section, const char* value) {
if (!sLang) return NULL; if (!sLang) return NULL;
return (char*)ini_find_key(sLang, section, value); return (char*)ini_find_key(sLang, section, value);

View file

@ -215,7 +215,9 @@ fail:
* Deletes ini_t struct from memory. * Deletes ini_t struct from memory.
*/ */
void ini_free(ini_t *ini) { void ini_free(ini_t *ini) {
free(ini->data); if (ini) {
free(ini->data);
}
free(ini); free(ini);
} }