mirror of
https://github.com/CachyOS/New-Cli-Installer.git
synced 2025-01-23 22:42:31 +08:00
🧹 move setting locale into gucc
This commit is contained in:
parent
b5b307ee49
commit
61317a83a3
@ -20,6 +20,7 @@ add_library(${PROJECT_NAME} SHARED
|
|||||||
src/zfs.cpp include/gucc/zfs.hpp
|
src/zfs.cpp include/gucc/zfs.hpp
|
||||||
src/btrfs.cpp include/gucc/btrfs.hpp
|
src/btrfs.cpp include/gucc/btrfs.hpp
|
||||||
src/user.cpp include/gucc/user.hpp
|
src/user.cpp include/gucc/user.hpp
|
||||||
|
src/locale.cpp include/gucc/locale.hpp
|
||||||
#src/chwd_profiles.cpp src/chwd_profiles.hpp
|
#src/chwd_profiles.cpp src/chwd_profiles.hpp
|
||||||
#src/disk.cpp src/disk.hpp
|
#src/disk.cpp src/disk.hpp
|
||||||
)
|
)
|
||||||
|
13
gucc/include/gucc/locale.hpp
Normal file
13
gucc/include/gucc/locale.hpp
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
#ifndef LOCALE_HPP
|
||||||
|
#define LOCALE_HPP
|
||||||
|
|
||||||
|
#include <string_view> // for string_view
|
||||||
|
|
||||||
|
namespace gucc::locale {
|
||||||
|
|
||||||
|
// Set system language
|
||||||
|
auto set_locale(std::string_view locale, std::string_view mountpoint) noexcept -> bool;
|
||||||
|
|
||||||
|
} // namespace gucc::locale
|
||||||
|
|
||||||
|
#endif // LOCALE_HPP
|
@ -10,6 +10,7 @@ gucc_lib = library('gucc',
|
|||||||
'src/zfs.cpp',
|
'src/zfs.cpp',
|
||||||
'src/btrfs.cpp',
|
'src/btrfs.cpp',
|
||||||
'src/user.cpp',
|
'src/user.cpp',
|
||||||
|
'src/locale.cpp',
|
||||||
],
|
],
|
||||||
include_directories : [include_directories('include')],
|
include_directories : [include_directories('include')],
|
||||||
dependencies: deps
|
dependencies: deps
|
||||||
|
56
gucc/src/locale.cpp
Normal file
56
gucc/src/locale.cpp
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
#include "gucc/locale.hpp"
|
||||||
|
#include "gucc/io_utils.hpp"
|
||||||
|
#include "gucc/string_utils.hpp"
|
||||||
|
|
||||||
|
#include <fstream> // for ofstream
|
||||||
|
|
||||||
|
#include <fmt/compile.h>
|
||||||
|
#include <fmt/format.h>
|
||||||
|
|
||||||
|
#include <spdlog/spdlog.h>
|
||||||
|
|
||||||
|
using namespace std::string_view_literals;
|
||||||
|
|
||||||
|
namespace gucc::locale {
|
||||||
|
|
||||||
|
auto set_locale(std::string_view locale, std::string_view mountpoint) noexcept -> bool {
|
||||||
|
const auto& locale_config_path = fmt::format(FMT_COMPILE("{}/etc/locale.conf"), mountpoint);
|
||||||
|
const auto& locale_gen_path = fmt::format(FMT_COMPILE("{}/etc/locale.gen"), mountpoint);
|
||||||
|
|
||||||
|
static constexpr auto LOCALE_CONFIG_PART = R"(LANG="{0}"
|
||||||
|
LC_NUMERIC="{0}"
|
||||||
|
LC_TIME="{0}"
|
||||||
|
LC_MONETARY="{0}"
|
||||||
|
LC_PAPER="{0}"
|
||||||
|
LC_NAME="{0}"
|
||||||
|
LC_ADDRESS="{0}"
|
||||||
|
LC_TELEPHONE="{0}"
|
||||||
|
LC_MEASUREMENT="{0}"
|
||||||
|
LC_IDENTIFICATION="{0}"
|
||||||
|
LC_MESSAGES="{0}"
|
||||||
|
)";
|
||||||
|
|
||||||
|
{
|
||||||
|
const auto& locale_config_text = fmt::format(LOCALE_CONFIG_PART, locale);
|
||||||
|
std::ofstream locale_config_file{locale_config_path, std::ios::out | std::ios::trunc};
|
||||||
|
if (!locale_config_file.is_open()) {
|
||||||
|
spdlog::error("Failed to open locale config for writing {}", locale_config_path);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
locale_config_file << locale_config_text;
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO(vnepogodin): refactor and make backups of locale config and locale gen
|
||||||
|
utils::exec(fmt::format(FMT_COMPILE("sed -i \"s/#{0}/{0}/\" {1}"), locale, locale_gen_path));
|
||||||
|
|
||||||
|
// Generate locales
|
||||||
|
if (!utils::arch_chroot_checked("locale-gen", mountpoint)) {
|
||||||
|
spdlog::error("Failed to run locale-gen with locale '{}'", locale);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// NOTE: maybe we should also write into /etc/default/locale if /etc/default exists and is a dir?
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace gucc::locale
|
@ -10,6 +10,7 @@
|
|||||||
#include "gucc/file_utils.hpp"
|
#include "gucc/file_utils.hpp"
|
||||||
#include "gucc/initcpio.hpp"
|
#include "gucc/initcpio.hpp"
|
||||||
#include "gucc/io_utils.hpp"
|
#include "gucc/io_utils.hpp"
|
||||||
|
#include "gucc/locale.hpp"
|
||||||
#include "gucc/luks.hpp"
|
#include "gucc/luks.hpp"
|
||||||
#include "gucc/pacmanconf_repo.hpp"
|
#include "gucc/pacmanconf_repo.hpp"
|
||||||
#include "gucc/string_utils.hpp"
|
#include "gucc/string_utils.hpp"
|
||||||
@ -388,31 +389,13 @@ void set_hostname(const std::string_view& hostname) noexcept {
|
|||||||
void set_locale(const std::string_view& locale) noexcept {
|
void set_locale(const std::string_view& locale) noexcept {
|
||||||
spdlog::info("Selected locale: {}", locale);
|
spdlog::info("Selected locale: {}", locale);
|
||||||
#ifdef NDEVENV
|
#ifdef NDEVENV
|
||||||
auto* config_instance = Config::instance();
|
auto* config_instance = Config::instance();
|
||||||
auto& config_data = config_instance->data();
|
auto& config_data = config_instance->data();
|
||||||
const auto& mountpoint = std::get<std::string>(config_data["MOUNTPOINT"]);
|
const auto& mountpoint = std::get<std::string>(config_data["MOUNTPOINT"]);
|
||||||
const auto& locale_config_path = fmt::format(FMT_COMPILE("{}/etc/locale.conf"), mountpoint);
|
|
||||||
const auto& locale_gen_path = fmt::format(FMT_COMPILE("{}/etc/locale.gen"), mountpoint);
|
|
||||||
|
|
||||||
static constexpr auto locale_config_part = R"(LANG="{0}"
|
if (!gucc::locale::set_locale(locale, mountpoint)) {
|
||||||
LC_NUMERIC="{0}"
|
spdlog::error("Failed to set locale");
|
||||||
LC_TIME="{0}"
|
}
|
||||||
LC_MONETARY="{0}"
|
|
||||||
LC_PAPER="{0}"
|
|
||||||
LC_NAME="{0}"
|
|
||||||
LC_ADDRESS="{0}"
|
|
||||||
LC_TELEPHONE="{0}"
|
|
||||||
LC_MEASUREMENT="{0}"
|
|
||||||
LC_IDENTIFICATION="{0}"
|
|
||||||
LC_MESSAGES="{0}")";
|
|
||||||
|
|
||||||
std::ofstream locale_config_file{locale_config_path};
|
|
||||||
locale_config_file << fmt::format(locale_config_part, locale);
|
|
||||||
|
|
||||||
gucc::utils::exec(fmt::format(FMT_COMPILE("sed -i \"s/#{0}/{0}/\" {1}"), locale, locale_gen_path));
|
|
||||||
|
|
||||||
// Generate locales
|
|
||||||
utils::arch_chroot("locale-gen", false);
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user