로거 완성

This commit is contained in:
2025-04-22 04:04:43 +09:00
parent 819bd5362e
commit 3a3cdc130a
11 changed files with 206 additions and 91 deletions

View File

@@ -1,13 +1,28 @@
#include "Socket/Log.hpp"
#include "spdlog/sinks/stdout_color_sinks.h"
#include "spdlog/sinks/rotating_file_sink.h"
#ifdef _WIN32
#include "spdlog/sinks/msvc_sink.h"
#endif
#include "precomp.hpp"
#include "spdlog/spdlog.h"
namespace Chattr::log {
void critical(gsl::czstring msg, bool bShowDBGMessage) {
if (!bShowDBGMessage)
spdlog::critical("{}", msg);
else {
void setDefaultLogger(spdlog::level::level_enum logLevel, gsl::czstring logFileName, std::uint32_t logFileSize, std::uint32_t logFileCount) {
std::vector<spdlog::sink_ptr> sinks;
sinks.push_back(std::make_shared<spdlog::sinks::stdout_color_sink_mt>());
sinks.push_back(std::make_shared<spdlog::sinks::rotating_file_sink_mt>(logFileName, logFileSize, logFileCount, false));
#ifdef _WIN32
sinks.push_back(std::make_shared<spdlog::sinks::msvc_sink_mt>());
#endif
auto chatteringLogger = std::make_shared<spdlog::logger>("Chattering Logger", begin(sinks), end(sinks));
chatteringLogger->set_level(logLevel);
spdlog::set_default_logger(chatteringLogger);
}
void critical(gsl::czstring msg) {
#ifdef _WIN32
gsl::zstring msgbuf = nullptr;
FormatMessageA(
@@ -26,14 +41,10 @@ void critical(gsl::czstring msg, bool bShowDBGMessage) {
#else
#error "이 플랫폼은 지원되지 않습니다."
#endif
}
std::exit(EXIT_FAILURE);
}
void error(gsl::czstring msg, bool bShowDBGMessage) {
if (!bShowDBGMessage)
spdlog::critical("{}", msg);
else {
void error(gsl::czstring msg) {
#ifdef _WIN32
gsl::zstring msgbuf = nullptr;
FormatMessageA(
@@ -52,7 +63,6 @@ void error(gsl::czstring msg, bool bShowDBGMessage) {
#else
#error "이 플랫폼은 지원되지 않습니다."
#endif
}
}
}

64
impl/Socket/Socket.cpp Normal file
View File

@@ -0,0 +1,64 @@
#include "Socket/Socket.hpp"
#include "Socket/Log.hpp"
#include "precomp.hpp"
namespace Chattr {
Socket::Socket(int domain, int type, int protocol) {
#ifdef _WIN32
WSADATA wsa;
if (WSAStartup(MAKEWORD(2, 2), &wsa) != 0)
log::critical("WSAStartup()");
#endif
sock_ = ::socket(domain, type, protocol);
if (sock_ == INVALID_SOCKET)
log::critical("socket()");
valid_ = true;
}
Socket::~Socket() {
if (!valid_)
return;
#ifdef _WIN32
closesocket(sock_);
WSACleanup();
#elif __linux__
::close(sock_);
#endif
}
Socket::operator SOCKET() const {
if (valid_)
return sock_;
spdlog::critical("No valid socket created.");
return INVALID_SOCKET;
};
void Socket::bind(int __fd, const sockaddr *__addr) {
bind(__fd, (struct sockaddr *)__addr, sizeof(*__addr));
}
void Socket::bind(int __fd, const sockaddr *__addr, socklen_t __len) {
int retVal = ::bind(__fd, __addr, __len);
if (retVal == INVALID_SOCKET)
log::critical("bind()");
}
void Socket::bind(int __fd, const sockaddr_in *__addr) {
bind(__fd, (struct sockaddr *)__addr, sizeof(*__addr));
}
void Socket::bind(int __fd, const sockaddr_in *__addr, socklen_t __len) {
bind(__fd, (struct sockaddr *)__addr, __len);
}
void Socket::bind(int __fd, const sockaddr_in6 *__addr) {
bind(__fd, (struct sockaddr *)__addr, sizeof(*__addr));
}
void Socket::bind(int __fd, const sockaddr_in6 *__addr, socklen_t __len) {
bind(__fd, (struct sockaddr *)__addr, __len);
}
}

View File

@@ -1,45 +0,0 @@
#include "Socket/Socket_Init.hpp"
#include "Socket/Log.hpp"
#include "precomp.hpp"
namespace Chattr {
Socket_Init::Socket_Init(std::int32_t domain, std::int32_t type, std::int32_t protocol)
{
#ifdef _WIN32
WSADATA wsa;
if (WSAStartup(MAKEWORD(2, 2), &wsa) != 0)
log::critical("WSAStartup()");
#endif
sock_ = socket(domain, type, protocol);
if (sock_ == INVALID_SOCKET)
log::critical("socket()");
valid_ = true;
}
Socket_Init::~Socket_Init() {
if (!valid_)
return;
#ifdef _WIN32
closesocket(sock_);
WSACleanup();
#elif __linux__
close(sock_);
#endif
}
Socket_Init::operator SOCKET() const {
if (valid_)
return sock_;
log::critical("No valid socket created.", false);
return INVALID_SOCKET;
};
void Socket_Init::bind(int __fd, const sockaddr *__addr, socklen_t __len) {
int retVal = ::bind(__fd, __addr, __len);
if (retVal == INVALID_SOCKET)
log::critical("bind()");
}
}