aboutsummaryrefslogtreecommitdiff
path: root/src/config.c
diff options
context:
space:
mode:
authorJan200101 <sentrycraft123@gmail.com>2020-08-18 23:58:16 +0200
committerJan200101 <sentrycraft123@gmail.com>2020-08-18 23:58:16 +0200
commitd53109eaa890ab807b66961a89291cea3cd3c003 (patch)
treea62382b32014266f5aecb6f639d0962bb1682bf0 /src/config.c
parent1753e2b151cbb4af75a4e9ea61720b3704b03805 (diff)
downloadpolecat-d53109eaa890ab807b66961a89291cea3cd3c003.tar.gz
polecat-d53109eaa890ab807b66961a89291cea3cd3c003.zip
first part of a proper lutris implementation and cleanup0.1.4
- remove all old build platform related variables - change behavior of clean - change tabs into spaces - make XDG fetching method static - replace strcpy and cat with strn alternative with proper bounds checking - add cache dir - reenable dxvk and download from ram - completely rework lutris fetching and convert it into an interal struct - only show http errors in debug - add sanity checks to methods with possible NULL return - change extracting methods to extract tar from ram
Diffstat (limited to 'src/config.c')
-rw-r--r--src/config.c19
1 files changed, 12 insertions, 7 deletions
diff --git a/src/config.c b/src/config.c
index f691648..b728e10 100644
--- a/src/config.c
+++ b/src/config.c
@@ -7,7 +7,7 @@
#include "config.h"
#include "common.h"
-void getXDGDir(const char* envvar, const char* homeext, char* config)
+static void getXDGDir(const char* envvar, const char* homeext, char* config, const size_t size)
{
char* xdg_var = getenv(envvar);
@@ -18,19 +18,24 @@ void getXDGDir(const char* envvar, const char* homeext, char* config)
else
{
char* home = getenv("HOME");
- strcpy(config, home);
- strcat(config, homeext);
+ strncpy(config, home, size);
+ strncat(config, homeext, size - strlen(config));
}
}
-void getConfigDir(char* config)
+void getConfigDir(char* config, const size_t size)
{
- getXDGDir("XDG_CONFIG_HOME", "/.config/" NAME, config);
+ getXDGDir("XDG_CONFIG_HOME", "/.config/" NAME, config, size);
}
-void getDataDir(char* config)
+void getDataDir(char* config, const size_t size)
{
- getXDGDir("XDG_DATA_HOME", "/.local/share/" NAME, config);
+ getXDGDir("XDG_DATA_HOME", "/.local/share/" NAME, config, size);
+}
+
+void getCacheDir(char* config, const size_t size)
+{
+ getXDGDir("XDG_CACHE_HOME", "/.cache/" NAME, config, size);
}
void makeDir(const char* path)