mirror of
https://github.com/obsqrbtz/clrsync.git
synced 2026-04-09 04:29:04 +03:00
init
This commit is contained in:
169
src/core/config/config.cpp
Normal file
169
src/core/config/config.cpp
Normal file
@@ -0,0 +1,169 @@
|
||||
#include "config.hpp"
|
||||
|
||||
#include <core/palette/color.hpp>
|
||||
#include <filesystem>
|
||||
#include <stdexcept>
|
||||
|
||||
namespace clrsync::core
|
||||
{
|
||||
config &config::instance()
|
||||
{
|
||||
static config inst;
|
||||
return inst;
|
||||
}
|
||||
|
||||
void config::initialize(std::unique_ptr<clrsync::core::io::file> file)
|
||||
{
|
||||
copy_default_configs();
|
||||
m_file = std::move(file);
|
||||
if (m_file)
|
||||
if (!m_file->parse())
|
||||
throw std::runtime_error{"Could not parse config file"};
|
||||
}
|
||||
|
||||
std::filesystem::path config::get_user_config_dir()
|
||||
{
|
||||
#ifdef _WIN32
|
||||
if (const char *appdata = std::getenv("APPDATA"))
|
||||
return fs::path(appdata) / "clrsync";
|
||||
else
|
||||
return fs::path("C:/clrsync");
|
||||
#else
|
||||
if (const char *xdg = std::getenv("XDG_CONFIG_HOME"))
|
||||
return std::filesystem::path(xdg) / "clrsync";
|
||||
else if (const char *home = std::getenv("HOME"))
|
||||
return std::filesystem::path(home) / ".config/clrsync";
|
||||
else
|
||||
return std::filesystem::path("/tmp/clrsync");
|
||||
#endif
|
||||
}
|
||||
|
||||
void config::copy_default_configs()
|
||||
{
|
||||
std::filesystem::path user_config = get_user_config_dir();
|
||||
|
||||
if (!std::filesystem::exists(user_config))
|
||||
{
|
||||
std::filesystem::create_directories(user_config);
|
||||
|
||||
std::filesystem::path default_dir = CLRSYNC_DATADIR;
|
||||
std::filesystem::copy(default_dir / "config.toml", user_config / "config.toml");
|
||||
std::filesystem::copy(default_dir / "templates", user_config / "templates",
|
||||
std::filesystem::copy_options::recursive);
|
||||
std::filesystem::copy(default_dir / "palettes", user_config / "palettes",
|
||||
std::filesystem::copy_options::recursive);
|
||||
}
|
||||
}
|
||||
|
||||
const std::string &config::palettes_path()
|
||||
{
|
||||
if (m_palettes_dir.empty() && m_file)
|
||||
m_palettes_dir = m_file->get_string_value("general", "palettes_path");
|
||||
return m_palettes_dir;
|
||||
}
|
||||
|
||||
const std::string config::default_theme() const
|
||||
{
|
||||
if (m_file)
|
||||
return m_file->get_string_value("general", "default_theme");
|
||||
return {};
|
||||
}
|
||||
|
||||
const std::string config::font() const
|
||||
{
|
||||
if (m_file)
|
||||
return m_file->get_string_value("general", "font");
|
||||
return {};
|
||||
}
|
||||
|
||||
const uint32_t config::font_size() const
|
||||
{
|
||||
if (m_file)
|
||||
return m_file->get_uint_value("general", "font_size");
|
||||
return 14;
|
||||
}
|
||||
|
||||
void config::set_default_theme(const std::string &theme)
|
||||
{
|
||||
if (m_file)
|
||||
{
|
||||
m_file->set_value("general", "default_theme", theme);
|
||||
m_file->save_file();
|
||||
}
|
||||
}
|
||||
|
||||
void config::set_palettes_path(const std::string &path)
|
||||
{
|
||||
if (m_file)
|
||||
{
|
||||
m_file->set_value("general", "palettes_path", path);
|
||||
m_file->save_file();
|
||||
}
|
||||
}
|
||||
|
||||
void config::set_font(const std::string &font)
|
||||
{
|
||||
if (m_file)
|
||||
{
|
||||
m_file->set_value("general", "font", font);
|
||||
m_file->save_file();
|
||||
}
|
||||
}
|
||||
void config::set_font_size(int font_size)
|
||||
{
|
||||
if (m_file)
|
||||
{
|
||||
m_file->set_value("general", "font_size", font_size);
|
||||
m_file->save_file();
|
||||
}
|
||||
}
|
||||
|
||||
void config::update_template(const std::string &key,
|
||||
const clrsync::core::theme_template &theme_template)
|
||||
{
|
||||
m_themes[key] = theme_template;
|
||||
m_file->set_value("templates." + key, "input_path", theme_template.template_path());
|
||||
m_file->set_value("templates." + key, "output_path", theme_template.output_path());
|
||||
m_file->set_value("templates." + key, "enabled", theme_template.enabled());
|
||||
m_file->set_value("templates." + key, "reload_cmd", theme_template.reload_command());
|
||||
m_file->save_file();
|
||||
}
|
||||
|
||||
const std::unordered_map<std::string, clrsync::core::theme_template> config::templates()
|
||||
{
|
||||
if (m_themes.empty() && m_file)
|
||||
{
|
||||
auto themes = m_file->get_table("templates");
|
||||
for (const auto &t : themes)
|
||||
{
|
||||
auto current = m_file->get_table("templates." + t.first);
|
||||
clrsync::core::theme_template theme(t.first,
|
||||
std::get<std::string>(current["input_path"]),
|
||||
std::get<std::string>(current["output_path"]));
|
||||
if (std::holds_alternative<bool>(current["enabled"]))
|
||||
{
|
||||
theme.set_enabled(std::get<bool>(current["enabled"]));
|
||||
}
|
||||
else
|
||||
{
|
||||
theme.set_enabled(false);
|
||||
}
|
||||
theme.set_reload_command(std::get<std::string>(current["reload_cmd"]));
|
||||
theme.load_template();
|
||||
m_themes.insert({theme.name(), theme});
|
||||
}
|
||||
}
|
||||
return m_themes;
|
||||
}
|
||||
|
||||
const clrsync::core::theme_template &config::template_by_name(const std::string &name) const
|
||||
{
|
||||
auto it = m_themes.find(name);
|
||||
if (it != m_themes.end())
|
||||
{
|
||||
return it->second;
|
||||
}
|
||||
throw std::runtime_error("Template not found: " + name);
|
||||
}
|
||||
|
||||
} // namespace clrsync::core
|
||||
Reference in New Issue
Block a user