로거 완성
This commit is contained in:
@@ -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
64
impl/Socket/Socket.cpp
Normal 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);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -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()");
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user