From 28f66dee8a9fe49aadb5c1d67de48d9232363963 Mon Sep 17 00:00:00 2001 From: alpine Date: Thu, 4 Jun 2020 16:13:19 +0200 Subject: Initial commit --- server/src/util/io.cpp | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 server/src/util/io.cpp (limited to 'server/src/util/io.cpp') diff --git a/server/src/util/io.cpp b/server/src/util/io.cpp new file mode 100644 index 0000000..1f9bca6 --- /dev/null +++ b/server/src/util/io.cpp @@ -0,0 +1,41 @@ +#include "../include.h" +#include "io.h" + +std::shared_ptr io::logger; + +void io::init(const bool &trunc) { + auto sink = + std::make_shared(); + sink->set_pattern("[%R][%^%l%$] %v"); + + auto file_sink = std::make_shared("server.log", trunc); + + std::vector log_sinks; + log_sinks.emplace_back(sink); + log_sinks.emplace_back(file_sink); + + logger = std::make_shared("server", log_sinks.begin(), log_sinks.end()); + spdlog::register_logger(logger); + + spdlog::flush_every(std::chrono::seconds(1)); +} + +void io::read_file(const std::string_view name, std::vector &out) { + std::ifstream file(name.data()); + if (!file.good()) { + io::logger->error("failed to load {}.", name.data()); + return; + } + + file.unsetf(std::ios::skipws); + + file.seekg(0, std::ios::end); + const size_t size = file.tellg(); + file.seekg(0, std::ios::beg); + + out.resize(size); + + file.read(out.data(), size); + + file.close(); +} -- cgit v1.2.3