From f7ac0f2a1ea373d28f630021c8567f0afb035568 Mon Sep 17 00:00:00 2001 From: ouwou <26526779+ouwou@users.noreply.github.com> Date: Wed, 30 Jun 2021 19:21:29 -0400 Subject: allow config to go in ~/.config/abaddon --- platform.cpp | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) (limited to 'platform.cpp') diff --git a/platform.cpp b/platform.cpp index 48d2104..9448cc6 100644 --- a/platform.cpp +++ b/platform.cpp @@ -3,6 +3,8 @@ #include #include +using namespace std::literals::string_literals; + bool IsFolder(std::string_view path) { std::error_code ec; const auto status = std::filesystem::status(path, ec); @@ -10,6 +12,13 @@ bool IsFolder(std::string_view path) { return status.type() == std::filesystem::file_type::directory; } +bool IsFile(std::string_view path) { + std::error_code ec; + const auto status = std::filesystem::status(path, ec); + if (ec) return false; + return status.type() == std::filesystem::file_type::regular; +} + #if defined(_WIN32) && defined(_MSC_VER) #include #include @@ -73,6 +82,10 @@ std::string Platform::FindResourceFolder() { return "."; } +std::string Platform::FindConfigFile() { + return "./abaddon.ini"; +} + #elif defined(__linux__) std::string Platform::FindResourceFolder() { static std::string path; @@ -88,8 +101,23 @@ std::string Platform::FindResourceFolder() { found = true; return path; } + +std::string Platform::FindConfigFile() { + const auto home_path = std::string(std::getenv("HOME")) + "/.config/abaddon/abaddon.ini"; + for (const auto path : { "./abaddon.ini"s, home_path }) { + if (IsFile(path)) return path; + } + puts("can't find configuration file!"); + return "./abaddon.ini"; +} #else std::string Platform::FindResourceFolder() { puts("unknown OS, trying to load resources from cwd"); + return "."; +} + +std::string Platform::FindConfigFile() { + puts("unknown OS, trying to load config from cwd"); + return "./abaddon.ini"; } #endif -- cgit v1.2.3