2016-01-10 03:06:50 +00:00
|
|
|
/* RetroArch - A frontend for libretro.
|
2017-03-22 02:09:18 +00:00
|
|
|
* Copyright (C) 2011-2017 - Daniel De Matteis
|
2019-06-23 22:23:39 +00:00
|
|
|
* Copyright (C) 2016-2019 - Brad Parker
|
2017-11-23 11:58:19 +00:00
|
|
|
*
|
2016-01-10 03:06:50 +00:00
|
|
|
* RetroArch is free software: you can redistribute it and/or modify it under the terms
|
|
|
|
* of the GNU General Public License as published by the Free Software Found-
|
|
|
|
* ation, either version 3 of the License, or (at your option) any later version.
|
2015-03-13 04:03:50 +00:00
|
|
|
*
|
2016-01-10 03:06:50 +00:00
|
|
|
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
|
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE. See the GNU General Public License for more details.
|
2015-03-13 04:03:50 +00:00
|
|
|
*
|
2016-01-10 03:06:50 +00:00
|
|
|
* You should have received a copy of the GNU General Public License along with RetroArch.
|
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
2015-03-13 04:03:50 +00:00
|
|
|
*/
|
|
|
|
|
2017-12-27 02:55:53 +00:00
|
|
|
/* Assume W-functions do not work below Win2K and Xbox platforms */
|
|
|
|
#if defined(_WIN32_WINNT) && _WIN32_WINNT < 0x0500 || defined(_XBOX)
|
|
|
|
|
|
|
|
#ifndef LEGACY_WIN32
|
|
|
|
#define LEGACY_WIN32
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|
2015-03-13 04:03:50 +00:00
|
|
|
|
2015-09-04 18:51:50 +00:00
|
|
|
#ifdef _WIN32
|
|
|
|
#include <direct.h>
|
|
|
|
#else
|
2015-09-22 19:49:03 +00:00
|
|
|
#include <unistd.h>
|
2015-03-13 04:03:50 +00:00
|
|
|
#endif
|
|
|
|
|
2016-12-26 15:50:08 +00:00
|
|
|
#ifdef __QNX__
|
|
|
|
#include <libgen.h>
|
|
|
|
#endif
|
|
|
|
|
2017-11-25 19:25:37 +00:00
|
|
|
#ifdef __HAIKU__
|
|
|
|
#include <kernel/image.h>
|
|
|
|
#endif
|
|
|
|
|
2016-09-08 03:48:43 +00:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <boolean.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <time.h>
|
|
|
|
#include <errno.h>
|
|
|
|
|
2015-09-01 09:59:27 +00:00
|
|
|
#include <file/file_path.h>
|
2016-06-11 18:21:22 +00:00
|
|
|
#include <string/stdstring.h>
|
2015-11-23 11:03:38 +00:00
|
|
|
|
2015-09-01 09:59:27 +00:00
|
|
|
#include <compat/strl.h>
|
|
|
|
#include <compat/posix_string.h>
|
|
|
|
#include <retro_assert.h>
|
|
|
|
#include <retro_miscellaneous.h>
|
2017-12-27 02:55:53 +00:00
|
|
|
#include <encodings/utf.h>
|
2015-09-01 09:59:27 +00:00
|
|
|
|
2019-01-27 16:22:16 +00:00
|
|
|
#ifdef HAVE_MENU
|
2019-01-28 12:06:41 +00:00
|
|
|
#include "menu/menu_driver.h"
|
2019-01-27 16:22:16 +00:00
|
|
|
#endif
|
|
|
|
|
2016-09-08 03:48:43 +00:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
#include "config.h"
|
|
|
|
#endif
|
|
|
|
|
2016-06-11 17:21:58 +00:00
|
|
|
#include "configuration.h"
|
|
|
|
#include "file_path_special.h"
|
|
|
|
|
2016-09-17 11:14:14 +00:00
|
|
|
#include "paths.h"
|
2015-11-23 11:03:38 +00:00
|
|
|
#include "verbosity.h"
|
|
|
|
|
2016-05-01 13:07:45 +00:00
|
|
|
bool fill_pathname_application_data(char *s, size_t len)
|
|
|
|
{
|
2018-05-12 17:17:23 +00:00
|
|
|
#if defined(_WIN32) && !defined(_XBOX) && !defined(__WINRT__)
|
2017-12-27 02:55:53 +00:00
|
|
|
#ifdef LEGACY_WIN32
|
2016-05-01 13:07:45 +00:00
|
|
|
const char *appdata = getenv("APPDATA");
|
|
|
|
|
|
|
|
if (appdata)
|
|
|
|
{
|
|
|
|
strlcpy(s, appdata, len);
|
|
|
|
return true;
|
|
|
|
}
|
2017-12-27 02:55:53 +00:00
|
|
|
#else
|
|
|
|
const wchar_t *appdataW = _wgetenv(L"APPDATA");
|
|
|
|
|
|
|
|
if (appdataW)
|
|
|
|
{
|
|
|
|
char *appdata = utf16_to_utf8_string_alloc(appdataW);
|
|
|
|
|
|
|
|
if (appdata)
|
|
|
|
{
|
|
|
|
strlcpy(s, appdata, len);
|
|
|
|
free(appdata);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
2016-05-01 13:07:45 +00:00
|
|
|
|
|
|
|
#elif defined(OSX)
|
|
|
|
const char *appdata = getenv("HOME");
|
|
|
|
|
|
|
|
if (appdata)
|
|
|
|
{
|
|
|
|
fill_pathname_join(s, appdata,
|
2016-05-02 11:23:47 +00:00
|
|
|
"Library/Application Support/RetroArch", len);
|
2016-05-01 13:07:45 +00:00
|
|
|
return true;
|
|
|
|
}
|
2016-05-01 13:59:55 +00:00
|
|
|
#elif !defined(RARCH_CONSOLE)
|
2016-05-01 13:07:45 +00:00
|
|
|
const char *xdg = getenv("XDG_CONFIG_HOME");
|
|
|
|
const char *appdata = getenv("HOME");
|
|
|
|
|
2018-01-20 08:19:01 +00:00
|
|
|
/* XDG_CONFIG_HOME falls back to $HOME/.config with most Unix systems */
|
|
|
|
/* On Haiku, it is set by default to /home/user/config/settings */
|
2016-05-01 13:07:45 +00:00
|
|
|
if (xdg)
|
|
|
|
{
|
2018-01-20 08:19:01 +00:00
|
|
|
fill_pathname_join(s, xdg, "retroarch/", len);
|
2016-05-01 13:07:45 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (appdata)
|
|
|
|
{
|
|
|
|
#ifdef __HAIKU__
|
2018-01-20 08:19:01 +00:00
|
|
|
/* in theory never used as Haiku has XDG_CONFIG_HOME set by default */
|
2016-05-01 13:07:45 +00:00
|
|
|
fill_pathname_join(s, appdata,
|
2016-05-02 00:48:37 +00:00
|
|
|
"config/settings/retroarch/", len);
|
2016-05-01 13:07:45 +00:00
|
|
|
#else
|
|
|
|
fill_pathname_join(s, appdata,
|
2016-05-02 00:48:37 +00:00
|
|
|
".config/retroarch/", len);
|
2016-05-01 13:07:45 +00:00
|
|
|
#endif
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-06-11 17:21:58 +00:00
|
|
|
#ifdef HAVE_XMB
|
2017-01-14 09:06:56 +00:00
|
|
|
const char* xmb_theme_ident(void);
|
2016-06-11 17:21:58 +00:00
|
|
|
#endif
|
|
|
|
|
2018-04-08 02:55:16 +00:00
|
|
|
#ifdef HAVE_STRIPES
|
|
|
|
const char* stripes_theme_ident(void);
|
|
|
|
#endif
|
|
|
|
|
2017-09-10 19:27:50 +00:00
|
|
|
void fill_pathname_application_special(char *s,
|
|
|
|
size_t len, enum application_special_type type)
|
2016-06-11 17:21:58 +00:00
|
|
|
{
|
|
|
|
switch (type)
|
|
|
|
{
|
2016-06-11 19:51:28 +00:00
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_AUTOCONFIG:
|
|
|
|
{
|
|
|
|
settings_t *settings = config_get_ptr();
|
|
|
|
fill_pathname_join(s,
|
2017-04-28 22:39:29 +00:00
|
|
|
settings->paths.directory_autoconfig,
|
2017-04-28 20:59:13 +00:00
|
|
|
settings->arrays.input_joypad_driver,
|
2016-06-11 19:51:28 +00:00
|
|
|
len);
|
|
|
|
}
|
|
|
|
break;
|
2016-06-11 19:55:55 +00:00
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_CONFIG:
|
|
|
|
{
|
|
|
|
settings_t *settings = config_get_ptr();
|
2016-09-17 11:14:14 +00:00
|
|
|
|
2016-06-11 19:55:55 +00:00
|
|
|
/* Try config directory setting first,
|
|
|
|
* fallback to the location of the current configuration file. */
|
2017-04-28 22:39:29 +00:00
|
|
|
if (!string_is_empty(settings->paths.directory_menu_config))
|
|
|
|
strlcpy(s, settings->paths.directory_menu_config, len);
|
2016-09-30 02:43:16 +00:00
|
|
|
else if (!path_is_empty(RARCH_PATH_CONFIG))
|
2016-09-29 06:31:41 +00:00
|
|
|
fill_pathname_basedir(s, path_get(RARCH_PATH_CONFIG), len);
|
2016-06-11 19:55:55 +00:00
|
|
|
}
|
|
|
|
break;
|
2016-06-11 17:55:27 +00:00
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_ASSETS_XMB_ICONS:
|
2016-06-11 17:37:16 +00:00
|
|
|
#ifdef HAVE_XMB
|
|
|
|
{
|
2017-09-10 19:27:50 +00:00
|
|
|
char *s1 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2019-09-16 18:40:08 +00:00
|
|
|
char *s2 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2016-10-21 03:57:40 +00:00
|
|
|
|
2019-09-16 15:44:14 +00:00
|
|
|
s1[0] = '\0';
|
2019-09-16 18:40:08 +00:00
|
|
|
s2[0] = '\0';
|
2016-10-21 03:57:40 +00:00
|
|
|
|
2017-09-10 19:27:50 +00:00
|
|
|
fill_pathname_application_special(s1,
|
|
|
|
PATH_MAX_LENGTH * sizeof(char),
|
2016-06-11 17:55:27 +00:00
|
|
|
APPLICATION_SPECIAL_DIRECTORY_ASSETS_XMB);
|
2019-09-16 18:40:08 +00:00
|
|
|
fill_pathname_join(s2, s1, "png",
|
|
|
|
PATH_MAX_LENGTH * sizeof(char)
|
|
|
|
);
|
|
|
|
fill_pathname_slash(s2,
|
|
|
|
PATH_MAX_LENGTH * sizeof(char)
|
|
|
|
);
|
|
|
|
strlcpy(s, s2, len);
|
2017-09-10 19:27:50 +00:00
|
|
|
free(s1);
|
2019-09-16 18:40:08 +00:00
|
|
|
free(s2);
|
2016-06-11 17:37:16 +00:00
|
|
|
}
|
2016-06-11 18:11:36 +00:00
|
|
|
#endif
|
|
|
|
break;
|
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_ASSETS_XMB_BG:
|
|
|
|
#ifdef HAVE_XMB
|
|
|
|
{
|
|
|
|
settings_t *settings = config_get_ptr();
|
|
|
|
|
2017-04-28 22:39:29 +00:00
|
|
|
if (!string_is_empty(settings->paths.path_menu_wallpaper))
|
|
|
|
strlcpy(s, settings->paths.path_menu_wallpaper, len);
|
2016-06-11 18:11:36 +00:00
|
|
|
else
|
2016-06-11 18:16:34 +00:00
|
|
|
{
|
2017-09-10 19:27:50 +00:00
|
|
|
char *s1 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2016-10-21 03:57:40 +00:00
|
|
|
|
|
|
|
s1[0] = '\0';
|
|
|
|
|
2017-09-10 19:27:50 +00:00
|
|
|
fill_pathname_application_special(s1,
|
|
|
|
PATH_MAX_LENGTH * sizeof(char),
|
2016-06-11 18:16:34 +00:00
|
|
|
APPLICATION_SPECIAL_DIRECTORY_ASSETS_XMB_ICONS);
|
2019-09-18 16:12:57 +00:00
|
|
|
fill_pathname_join(s, s1, "bg.png", len);
|
2017-09-10 19:27:50 +00:00
|
|
|
free(s1);
|
2016-06-11 18:16:34 +00:00
|
|
|
}
|
2016-06-11 18:11:36 +00:00
|
|
|
}
|
2019-01-27 16:22:16 +00:00
|
|
|
#endif
|
|
|
|
break;
|
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_ASSETS_SOUNDS:
|
|
|
|
{
|
|
|
|
#ifdef HAVE_MENU
|
|
|
|
settings_t *settings = config_get_ptr();
|
|
|
|
const char *menu_ident = settings->arrays.menu_driver;
|
|
|
|
char *s1 = (char*)calloc(1, PATH_MAX_LENGTH * sizeof(char));
|
|
|
|
|
|
|
|
if (string_is_equal(menu_ident, "xmb"))
|
|
|
|
{
|
|
|
|
fill_pathname_application_special(s1, PATH_MAX_LENGTH * sizeof(char), APPLICATION_SPECIAL_DIRECTORY_ASSETS_XMB);
|
|
|
|
|
|
|
|
if (!string_is_empty(s1))
|
|
|
|
strlcat(s1, "/sounds", PATH_MAX_LENGTH * sizeof(char));
|
|
|
|
}
|
|
|
|
else if (string_is_equal(menu_ident, "glui"))
|
|
|
|
{
|
|
|
|
fill_pathname_application_special(s1, PATH_MAX_LENGTH * sizeof(char), APPLICATION_SPECIAL_DIRECTORY_ASSETS_MATERIALUI);
|
|
|
|
|
|
|
|
if (!string_is_empty(s1))
|
|
|
|
strlcat(s1, "/sounds", PATH_MAX_LENGTH * sizeof(char));
|
|
|
|
}
|
|
|
|
else if (string_is_equal(menu_ident, "ozone"))
|
|
|
|
{
|
|
|
|
fill_pathname_application_special(s1, PATH_MAX_LENGTH * sizeof(char), APPLICATION_SPECIAL_DIRECTORY_ASSETS_OZONE);
|
|
|
|
|
|
|
|
if (!string_is_empty(s1))
|
|
|
|
strlcat(s1, "/sounds", PATH_MAX_LENGTH * sizeof(char));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (string_is_empty(s1))
|
|
|
|
{
|
|
|
|
fill_pathname_join(
|
|
|
|
s1,
|
|
|
|
settings->paths.directory_assets,
|
|
|
|
"sounds",
|
|
|
|
PATH_MAX_LENGTH * sizeof(char)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
strlcpy(s, s1, len);
|
|
|
|
free(s1);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_ASSETS_OZONE:
|
|
|
|
#ifdef HAVE_OZONE
|
|
|
|
{
|
|
|
|
char *s1 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
|
|
|
settings_t *settings = config_get_ptr();
|
|
|
|
|
|
|
|
s1[0] = '\0';
|
|
|
|
|
|
|
|
fill_pathname_join(
|
|
|
|
s1,
|
|
|
|
settings->paths.directory_assets,
|
|
|
|
"ozone",
|
|
|
|
PATH_MAX_LENGTH * sizeof(char)
|
|
|
|
);
|
|
|
|
strlcpy(s, s1, len);
|
|
|
|
free(s1);
|
|
|
|
}
|
2016-06-11 17:37:16 +00:00
|
|
|
#endif
|
|
|
|
break;
|
2016-06-11 17:55:27 +00:00
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_ASSETS_XMB:
|
2016-06-11 17:21:58 +00:00
|
|
|
#ifdef HAVE_XMB
|
|
|
|
{
|
2017-09-10 19:27:50 +00:00
|
|
|
char *s1 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2016-06-11 17:21:58 +00:00
|
|
|
settings_t *settings = config_get_ptr();
|
|
|
|
|
2019-09-16 15:44:14 +00:00
|
|
|
s1[0] = '\0';
|
2016-10-21 03:57:40 +00:00
|
|
|
|
2016-06-11 17:21:58 +00:00
|
|
|
fill_pathname_join(
|
|
|
|
s1,
|
2017-04-28 22:39:29 +00:00
|
|
|
settings->paths.directory_assets,
|
2016-06-11 17:21:58 +00:00
|
|
|
"xmb",
|
2017-09-10 19:27:50 +00:00
|
|
|
PATH_MAX_LENGTH * sizeof(char)
|
|
|
|
);
|
2019-09-16 15:44:14 +00:00
|
|
|
fill_pathname_join(s,
|
|
|
|
s1, xmb_theme_ident(), len);
|
2017-09-10 19:27:50 +00:00
|
|
|
free(s1);
|
2016-06-11 17:21:58 +00:00
|
|
|
}
|
2016-06-11 17:41:26 +00:00
|
|
|
#endif
|
|
|
|
break;
|
2016-06-11 17:55:27 +00:00
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_ASSETS_MATERIALUI:
|
2016-06-11 17:41:26 +00:00
|
|
|
#ifdef HAVE_MATERIALUI
|
|
|
|
{
|
2016-06-11 17:46:37 +00:00
|
|
|
settings_t *settings = config_get_ptr();
|
|
|
|
|
2016-06-11 17:41:26 +00:00
|
|
|
fill_pathname_join(
|
2016-06-11 17:46:37 +00:00
|
|
|
s,
|
2017-04-28 22:39:29 +00:00
|
|
|
settings->paths.directory_assets,
|
2016-06-11 17:41:26 +00:00
|
|
|
"glui",
|
2016-06-11 17:46:37 +00:00
|
|
|
len);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
break;
|
2016-06-11 17:55:27 +00:00
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_ASSETS_MATERIALUI_ICONS:
|
2016-06-11 17:46:37 +00:00
|
|
|
#ifdef HAVE_MATERIALUI
|
|
|
|
{
|
2017-09-10 19:27:50 +00:00
|
|
|
char *s1 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2016-10-21 03:57:40 +00:00
|
|
|
|
|
|
|
s1[0] = '\0';
|
|
|
|
|
2016-06-11 17:55:27 +00:00
|
|
|
fill_pathname_application_special(s1,
|
2017-09-10 19:27:50 +00:00
|
|
|
PATH_MAX_LENGTH * sizeof(char),
|
|
|
|
APPLICATION_SPECIAL_DIRECTORY_ASSETS_MATERIALUI);
|
2019-09-16 18:40:08 +00:00
|
|
|
fill_pathname_slash(s1,
|
|
|
|
PATH_MAX_LENGTH * sizeof(char)
|
|
|
|
);
|
2016-06-11 17:41:26 +00:00
|
|
|
strlcpy(s, s1, len);
|
2017-09-10 19:27:50 +00:00
|
|
|
|
|
|
|
free(s1);
|
2016-06-11 17:41:26 +00:00
|
|
|
}
|
2016-06-11 17:57:45 +00:00
|
|
|
#endif
|
|
|
|
break;
|
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_ASSETS_MATERIALUI_FONT:
|
|
|
|
#ifdef HAVE_MATERIALUI
|
|
|
|
{
|
2017-09-10 19:27:50 +00:00
|
|
|
char *s1 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2016-10-21 03:57:40 +00:00
|
|
|
|
|
|
|
s1[0] = '\0';
|
|
|
|
|
2017-09-10 19:27:50 +00:00
|
|
|
fill_pathname_application_special(s1,
|
|
|
|
PATH_MAX_LENGTH * sizeof(char),
|
2016-06-11 17:57:45 +00:00
|
|
|
APPLICATION_SPECIAL_DIRECTORY_ASSETS_MATERIALUI);
|
2016-11-02 17:18:04 +00:00
|
|
|
fill_pathname_join(s, s1, "font.ttf", len);
|
2017-09-10 19:27:50 +00:00
|
|
|
|
|
|
|
free(s1);
|
2016-06-11 17:57:45 +00:00
|
|
|
}
|
2016-06-11 18:01:33 +00:00
|
|
|
#endif
|
|
|
|
break;
|
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_ASSETS_XMB_FONT:
|
|
|
|
#ifdef HAVE_XMB
|
|
|
|
{
|
2016-06-11 18:21:22 +00:00
|
|
|
settings_t *settings = config_get_ptr();
|
2016-06-11 18:01:33 +00:00
|
|
|
|
2017-04-28 22:39:29 +00:00
|
|
|
if (!string_is_empty(settings->paths.path_menu_xmb_font))
|
|
|
|
strlcpy(s, settings->paths.path_menu_xmb_font, len);
|
2016-06-11 18:21:22 +00:00
|
|
|
else
|
2016-06-11 18:22:03 +00:00
|
|
|
{
|
2017-09-10 19:27:50 +00:00
|
|
|
char *s1 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2016-10-21 03:57:40 +00:00
|
|
|
|
|
|
|
s1[0] = '\0';
|
|
|
|
|
2017-09-10 19:27:50 +00:00
|
|
|
fill_pathname_application_special(s1,
|
|
|
|
PATH_MAX_LENGTH * sizeof(char),
|
2016-06-11 18:22:03 +00:00
|
|
|
APPLICATION_SPECIAL_DIRECTORY_ASSETS_XMB);
|
2019-09-18 16:12:57 +00:00
|
|
|
fill_pathname_join(s, s1, "font.ttf", len);
|
2017-09-10 19:27:50 +00:00
|
|
|
free(s1);
|
2016-06-11 18:22:03 +00:00
|
|
|
}
|
2016-06-11 18:01:33 +00:00
|
|
|
}
|
2016-06-11 17:21:58 +00:00
|
|
|
#endif
|
|
|
|
break;
|
2018-10-17 06:08:15 +00:00
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_THUMBNAILS_DISCORD_AVATARS:
|
|
|
|
{
|
2019-09-16 15:44:14 +00:00
|
|
|
char *s1 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2019-09-16 18:40:08 +00:00
|
|
|
char *s2 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2019-09-16 15:44:14 +00:00
|
|
|
settings_t *settings = config_get_ptr();
|
2018-10-17 06:08:15 +00:00
|
|
|
|
2019-09-16 15:44:14 +00:00
|
|
|
s1[0] = '\0';
|
2019-09-16 18:40:08 +00:00
|
|
|
s2[0] = '\0';
|
2018-10-17 06:08:15 +00:00
|
|
|
|
|
|
|
fill_pathname_join(s1,
|
|
|
|
settings->paths.directory_thumbnails,
|
|
|
|
"discord",
|
|
|
|
len);
|
2019-09-16 18:40:08 +00:00
|
|
|
fill_pathname_join(s2,
|
|
|
|
s1, "avatars",
|
|
|
|
PATH_MAX_LENGTH * sizeof(char)
|
|
|
|
);
|
|
|
|
fill_pathname_slash(s2,
|
|
|
|
PATH_MAX_LENGTH * sizeof(char)
|
|
|
|
);
|
|
|
|
strlcpy(s, s2, len);
|
2018-10-17 06:08:15 +00:00
|
|
|
free(s1);
|
2019-09-16 18:40:08 +00:00
|
|
|
free(s2);
|
2018-10-17 06:08:15 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2017-11-23 11:58:19 +00:00
|
|
|
case APPLICATION_SPECIAL_DIRECTORY_THUMBNAILS_CHEEVOS_BADGES:
|
|
|
|
{
|
2019-09-16 15:44:14 +00:00
|
|
|
char *s1 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2019-09-16 18:40:08 +00:00
|
|
|
char *s2 = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2019-09-16 15:44:14 +00:00
|
|
|
settings_t *settings = config_get_ptr();
|
2017-11-23 11:58:19 +00:00
|
|
|
|
2019-09-16 15:44:14 +00:00
|
|
|
s1[0] = '\0';
|
2019-09-16 18:40:08 +00:00
|
|
|
s2[0] = '\0';
|
2017-11-23 11:58:19 +00:00
|
|
|
|
|
|
|
fill_pathname_join(s1,
|
|
|
|
settings->paths.directory_thumbnails,
|
|
|
|
"cheevos",
|
|
|
|
len);
|
2019-09-16 18:40:08 +00:00
|
|
|
fill_pathname_join(s2,
|
|
|
|
s1, "badges",
|
|
|
|
PATH_MAX_LENGTH * sizeof(char)
|
|
|
|
);
|
|
|
|
fill_pathname_slash(s2,
|
|
|
|
PATH_MAX_LENGTH * sizeof(char)
|
|
|
|
);
|
|
|
|
strlcpy(s, s2, len);
|
2017-11-23 11:58:19 +00:00
|
|
|
free(s1);
|
2019-09-16 18:40:08 +00:00
|
|
|
free(s2);
|
2017-11-23 11:58:19 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2016-06-11 17:55:27 +00:00
|
|
|
case APPLICATION_SPECIAL_NONE:
|
2016-06-11 17:21:58 +00:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2016-12-17 10:54:46 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* fill_short_pathname_representation:
|
|
|
|
* @out_rep : output representation
|
|
|
|
* @in_path : input path
|
|
|
|
* @size : size of output representation
|
|
|
|
*
|
|
|
|
* Generates a short representation of path. It should only
|
|
|
|
* be used for displaying the result; the output representation is not
|
|
|
|
* binding in any meaningful way (for a normal path, this is the same as basename)
|
|
|
|
* In case of more complex URLs, this should cut everything except for
|
|
|
|
* the main image file.
|
|
|
|
*
|
|
|
|
* E.g.: "/path/to/game.img" -> game.img
|
|
|
|
* "/path/to/myarchive.7z#folder/to/game.img" -> game.img
|
|
|
|
*/
|
|
|
|
void fill_short_pathname_representation_wrapper(char* out_rep,
|
|
|
|
const char *in_path, size_t size)
|
|
|
|
{
|
|
|
|
#ifdef HAVE_COMPRESSION
|
2018-02-04 22:40:27 +00:00
|
|
|
char *path_short = (char*)malloc(PATH_MAX_LENGTH * sizeof(char));
|
2017-09-10 19:27:50 +00:00
|
|
|
char *last_slash = NULL;
|
2016-12-17 10:54:46 +00:00
|
|
|
|
2018-02-04 22:40:27 +00:00
|
|
|
path_short[0] = '\0';
|
2016-12-17 10:54:46 +00:00
|
|
|
|
|
|
|
fill_pathname(path_short, path_basename(in_path), "",
|
2017-09-10 19:27:50 +00:00
|
|
|
PATH_MAX_LENGTH * sizeof(char)
|
|
|
|
);
|
2016-12-17 10:54:46 +00:00
|
|
|
|
|
|
|
last_slash = find_last_slash(path_short);
|
2018-02-04 22:40:27 +00:00
|
|
|
|
2016-12-17 10:54:46 +00:00
|
|
|
if (last_slash != NULL)
|
|
|
|
{
|
|
|
|
/* We handle paths like:
|
|
|
|
* /path/to/file.7z#mygame.img
|
|
|
|
* short_name: mygame.img:
|
|
|
|
*
|
|
|
|
* We check whether something is actually
|
|
|
|
* after the hash to avoid going over the buffer.
|
|
|
|
*/
|
|
|
|
strlcpy(out_rep, last_slash + 1, size);
|
2017-09-10 19:27:50 +00:00
|
|
|
free(path_short);
|
2016-12-17 10:54:46 +00:00
|
|
|
return;
|
|
|
|
}
|
2018-02-04 22:40:27 +00:00
|
|
|
|
|
|
|
free(path_short);
|
2016-12-17 10:54:46 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
fill_short_pathname_representation(out_rep, in_path, size);
|
|
|
|
}
|