summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFlorent Le Coz <louiz@louiz.org>2015-09-18 09:39:49 +0200
committerFlorent Le Coz <louiz@louiz.org>2015-09-18 21:50:54 +0200
commit33fa1dcd5a87035de1d9b8df65e5c7551b4bbd1b (patch)
tree4aed271a59ee3ce6967c56e68388fc711a21dd38
parentea0b2f2bb871e7760d1936bb9b193655682df413 (diff)
downloadbiboumi-33fa1dcd5a87035de1d9b8df65e5c7551b4bbd1b.tar.gz
biboumi-33fa1dcd5a87035de1d9b8df65e5c7551b4bbd1b.tar.bz2
biboumi-33fa1dcd5a87035de1d9b8df65e5c7551b4bbd1b.tar.xz
biboumi-33fa1dcd5a87035de1d9b8df65e5c7551b4bbd1b.zip
Also a xdg_data_path
-rw-r--r--louloulibs/utils/xdg.cpp17
-rw-r--r--louloulibs/utils/xdg.hpp1
-rw-r--r--src/main.cpp2
-rw-r--r--src/test.cpp7
4 files changed, 22 insertions, 5 deletions
diff --git a/louloulibs/utils/xdg.cpp b/louloulibs/utils/xdg.cpp
index 7a60dd8..48212a1 100644
--- a/louloulibs/utils/xdg.cpp
+++ b/louloulibs/utils/xdg.cpp
@@ -3,11 +3,11 @@
#include "louloulibs.h"
-std::string xdg_config_path(const std::string& filename)
+std::string xdg_path(const std::string& filename, const char* env_var)
{
- const char* xdg_config_home = ::getenv("XDG_CONFIG_HOME");
- if (xdg_config_home && xdg_config_home[0] == '/')
- return std::string{xdg_config_home} + "/" PROJECT_NAME "/" + filename;
+ const char* xdg_home = ::getenv(env_var);
+ if (xdg_home && xdg_home[0] == '/')
+ return std::string{xdg_home} + "/" PROJECT_NAME "/" + filename;
else
{
const char* home = ::getenv("HOME");
@@ -18,3 +18,12 @@ std::string xdg_config_path(const std::string& filename)
}
}
+std::string xdg_config_path(const std::string& filename)
+{
+ return xdg_path(filename, "XDG_CONFIG_HOME");
+}
+
+std::string xdg_data_path(const std::string& filename)
+{
+ return xdg_path(filename, "XDG_DATA_HOME");
+}
diff --git a/louloulibs/utils/xdg.hpp b/louloulibs/utils/xdg.hpp
index 20f5bb7..15f3d0b 100644
--- a/louloulibs/utils/xdg.hpp
+++ b/louloulibs/utils/xdg.hpp
@@ -9,5 +9,6 @@
* http://standards.freedesktop.org/basedir-spec/basedir-spec-latest.html
*/
std::string xdg_config_path(const std::string& filename);
+std::string xdg_data_path(const std::string& filename);
#endif /* XDG_HPP_INCLUDED */
diff --git a/src/main.cpp b/src/main.cpp
index 5c9e071..a160df9 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -69,7 +69,7 @@ int main(int ac, char** av)
if (ac > 1)
Config::filename = av[1];
else
- Config::filename = xdg_path("biboumi.cfg");
+ Config::filename = xdg_config_path("biboumi.cfg");
Config::file_must_exist = true;
std::cerr << "Using configuration file: " << Config::filename << std::endl;
diff --git a/src/test.cpp b/src/test.cpp
index b8737e6..3ac0332 100644
--- a/src/test.cpp
+++ b/src/test.cpp
@@ -13,6 +13,7 @@
#include <utils/revstr.hpp>
#include <irc/irc_user.hpp>
#include <utils/split.hpp>
+#include <utils/xdg.hpp>
#include <xmpp/jid.hpp>
#include <irc/iid.hpp>
#include <string.h>
@@ -423,6 +424,12 @@ int main()
res = xdg_config_path("coucou.txt");
std::cout << res << std::endl;
assert(res == "/some_weird_dir/biboumi/coucou.txt");
+
+ ::setenv("XDG_DATA_HOME", "/datadir", 1);
+ res = xdg_data_path("bonjour.txt");
+ std::cout << res << std::endl;
+ assert(res == "/datadir/biboumi/bonjour.txt");
+
}
return 0;