.dll .so 복사 자동화 완료

This commit is contained in:
2025-04-28 11:25:53 +09:00
parent f76e1b9a5d
commit 41c75b9dca
15 changed files with 165 additions and 69 deletions

View File

@@ -46,6 +46,14 @@ target_link_libraries(${PROJECT_NAME} PRIVATE jsoncpp_lib)
if(WIN32)
target_link_libraries(${PROJECT_NAME} PRIVATE ws2_32)
endif()
if(UNIX AND NOT APPLE AND CMAKE_BUILD_TYPE STREQUAL "Release")
set_target_properties(${PROJECT_NAME} PROPERTIES
BUILD_WITH_INSTALL_RPATH TRUE
INSTALL_RPATH "$ORIGIN"
SKIP_BUILD_RPATH FALSE
BUILD_RPATH "$ORIGIN"
)
endif()
target_include_directories(${PROJECT_NAME} PUBLIC
${CMAKE_CURRENT_SOURCE_DIR}/../include
@@ -55,17 +63,27 @@ target_compile_features(${PROJECT_NAME} PRIVATE cxx_std_20)
target_precompile_headers(${PROJECT_NAME} PRIVATE "${CMAKE_CURRENT_SOURCE_DIR}/../include/precomp.hpp")
if(WIN32)
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_if_different
"$<TARGET_FILE:spdlog>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying spdlog DLL to output directory"
)
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMENT "Copying spdlog DLL/so to output directory"
)
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_if_different
"$<TARGET_FILE:jsoncpp_lib>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying jsoncpp DLL to output directory"
)
endif()
COMMENT "Copying jsoncpp DLL/so to output directory"
)
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_directory
"$<TARGET_FILE_DIR:spdlog>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying spdlog library files and symlinks to output directory"
)
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_directory
"$<TARGET_FILE_DIR:jsoncpp_lib>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying jsoncpp library files and symlinks to output directory"
)

View File

@@ -5,10 +5,12 @@
int main() {
Chattr::TCPSocket sock;
sock.init(AF_INET6);
sock.init(AF_INET);
Chattr::Address serveraddr(AF_INET6, "::1", 9010);
Chattr::Address serveraddr(AF_INET, "localhost", 9011);
sock.connect(serveraddr);
spdlog::info("Connection established from {}, {}", sock, (std::string)serveraddr);
sock.send("Hello, World!", 14, 0);
sleep(100);
}

View File

@@ -47,6 +47,14 @@ target_link_libraries(${PROJECT_NAME} PRIVATE jsoncpp_lib)
if(WIN32)
target_link_libraries(${PROJECT_NAME} PRIVATE ws2_32)
endif()
if(UNIX AND NOT APPLE AND CMAKE_BUILD_TYPE STREQUAL "Release")
set_target_properties(${PROJECT_NAME} PROPERTIES
BUILD_WITH_INSTALL_RPATH TRUE
INSTALL_RPATH "$ORIGIN"
SKIP_BUILD_RPATH FALSE
BUILD_RPATH "$ORIGIN"
)
endif()
target_include_directories(${PROJECT_NAME} PUBLIC
${CMAKE_CURRENT_SOURCE_DIR}/../include
@@ -56,17 +64,27 @@ target_compile_features(${PROJECT_NAME} PRIVATE cxx_std_20)
target_precompile_headers(${PROJECT_NAME} PRIVATE "${CMAKE_CURRENT_SOURCE_DIR}/../include/precomp.hpp")
if(WIN32)
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_if_different
"$<TARGET_FILE:spdlog>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying spdlog DLL to output directory"
)
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMENT "Copying spdlog DLL/so to output directory"
)
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_if_different
"$<TARGET_FILE:jsoncpp_lib>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying jsoncpp DLL to output directory"
)
endif()
COMMENT "Copying jsoncpp DLL/so to output directory"
)
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_directory
"$<TARGET_FILE_DIR:spdlog>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying spdlog library files and symlinks to output directory"
)
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_directory
"$<TARGET_FILE_DIR:jsoncpp_lib>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying jsoncpp library files and symlinks to output directory"
)

View File

@@ -4,6 +4,7 @@
#include "Utils/ConfigManager.hpp"
#include "Utils/Thread.hpp"
#include "Utils/StringTokenizer.hpp"
#include "Session/Session.hpp"
#include "precomp.hpp"
@@ -31,16 +32,33 @@ int main() {
sock.bind(&serveraddr.addr, serveraddr.length);
sock.listen(SOMAXCONN);
#ifdef _WIN32
DWORD pid = GetCurrentProcessPid();
#elif __linux__
pid_t pid = getpid();
#endif
spdlog::info("PID : {}", pid);
while (true) {
spdlog::info("Waiting for connection...");
sock.accept(clientSock, clientAddr);
Chattr::Thread thread_(_TCPClient, std::move(clientSock), clientAddr);
thread_.deatch();
thread_.detach();
}
}
void _TCPClient(Chattr::TCPSocket sock, Chattr::Address addr) {
spdlog::info("Connection accepted! from: {}, {}", sock, (std::string)addr);
Sleep(10000);
spdlog::info("Connection accepted. [{}:{}]", sock, (std::string)addr);
char buf[1024];
while (true) {
int redSize = sock.recv(buf, 1024, 0);
if (redSize == 0)
break;
std::string recvData(buf, redSize);
spdlog::info("Red size : {}, {}", redSize, recvData);
}
spdlog::info("Client disconnected. [{}:{}]", sock, (std::string)addr);
}

View File

@@ -42,8 +42,7 @@ Socket::operator SOCKET() const {
return INVALID_SOCKET;
}
void Socket::move(const SOCKET __sock)
{
void Socket::set(const SOCKET __sock) {
if (__sock == INVALID_SOCKET)
log::critical("socket()");
@@ -53,14 +52,6 @@ void Socket::move(const SOCKET __sock)
valid_ = true;
};
Socket& Socket::move() {
std::shared_ptr<Socket> socket = std::make_shared<Socket>();
valid_ = false;
socket->move(sock_);
return *socket;
};
void Socket::bind(sockaddr *__addr) {
bind((struct sockaddr *)__addr, sizeof(sockaddr));
}
@@ -89,7 +80,21 @@ void Socket::bind(sockaddr_in6 *__addr, socklen_t __len) {
bind((struct sockaddr *)__addr, __len);
}
Socket::Socket(Socket&& other_) {
int Socket::recvfrom(void *__restrict __buf, size_t __n, int __flags, struct Address& __addr) {
int retVal = ::recvfrom(sock_, __buf, __n, __flags, &__addr.addr, &__addr.length);
if (retVal == SOCKET_ERROR)
log::error("recvfrom()");
return retVal;
}
int Socket::sendto(const void *__buf, size_t __n, int __flags, struct Address __addr) {
int retVal = ::sendto(sock_, __buf, __n, __flags, &__addr.addr, __addr.length);
if (retVal == SOCKET_ERROR)
log::error("sendto()");
return retVal;
}
Socket::Socket(Socket &&other_) {
other_.valid_ = false;
sock_ = other_.sock_;
valid_ = true;

View File

@@ -16,7 +16,7 @@ void TCPSocket::listen(int __n) {
}
void TCPSocket::accept(TCPSocket& newSock, Address& __addr) {
newSock.move(::accept(sock_, &__addr.addr, &__addr.length));
newSock.set(::accept(sock_, &__addr.addr, &__addr.length));
if (newSock == INVALID_SOCKET)
log::critical("accept()");
}
@@ -27,6 +27,18 @@ void TCPSocket::connect(Chattr::Address& serveraddr) {
log::critical("connect()");
}
int TCPSocket::recv(void *__restrict __buf, size_t __n, int __flags) {
int retVal = ::recv(sock_, __buf, __n, __flags);
if (retVal == SOCKET_ERROR)
log::error("recv()");
return retVal;
}
int TCPSocket::send(const void *__buf, size_t __n, int __flags) {
int retVal = ::send(sock_, __buf, __n, __flags);
if (retVal == SOCKET_ERROR)
log::error("send()");
return retVal;
}
}

View File

@@ -1,4 +1,3 @@
#pragma once
#include "Utils/StringTokenizer.hpp"
namespace Chattr {

View File

@@ -14,7 +14,7 @@ void Thread::join() {
#endif
}
void Thread::deatch() {
void Thread::detach() {
detached = true;
}

View File

@@ -0,0 +1,21 @@
#pragma once
#include "Socket/TCPSocket.hpp"
#include <vector>
namespace Chattr {
class Session {
public:
Session();
~Session();
bool init();
void destruct();
int send();
int recv();
private:
struct std::vector<Chattr::TCPSocket> tcpSock_;
struct std::vector<Chattr::Socket> udpSock_;
};
}

View File

@@ -1,19 +0,0 @@
#pragma once
namespace Chattr {
class Sesson {
public:
Sesson();
~Session();
bool init();
void destruct();
int send();
int recv();
private:
struct std::vector<Chattr::TCPSocket> sock;
struct std::vector<Chattr::Socket> sock;
};
}

View File

@@ -15,8 +15,7 @@ public:
void destruct();
operator SOCKET() const;
void move(const SOCKET);
Socket& move();
void set(const SOCKET);
void bind(sockaddr *__addr);
void bind(sockaddr *__addr, socklen_t __len);
@@ -29,6 +28,9 @@ public:
void bind(sockaddr_in6 *__addr);
void bind(sockaddr_in6 *__addr, socklen_t __len);
int recvfrom(void *__restrict __buf, size_t __n, int __flags, struct Address& __addr);
int sendto(const void *__buf, size_t __n, int __flags, struct Address __addr);
Socket(const Socket&) = delete;
Socket(Socket&&);
Socket& operator=(const Socket&) = delete;

View File

@@ -11,6 +11,8 @@ public:
void listen(int __n);
void accept(TCPSocket& newSock, Address& addr);
void connect(Chattr::Address& serveraddr);
int recv(void *__restrict __buf, size_t __n, int __flags);
int send(const void *__buf, size_t __n, int __flags);
};
}

View File

@@ -0,0 +1,17 @@
#pragma once
#include <cstdint>
namespace Chattr {
struct Snowflake {
union {
struct {
std::uint64_t timestamp : 42;
std::uint64_t instance : 10;
std::uint64_t sequence : 12;
};
std::uint64_t snowflake;
};
};
}

View File

@@ -45,7 +45,7 @@ public:
~Thread();
void join();
void deatch();
void detach();
private:
#ifdef _WIN32

View File

@@ -14,6 +14,7 @@
#include <netinet/in.h>
#define SOCKET int
#define INVALID_SOCKET -1
#define SOCKET_ERROR -1
#else
#error "이 플랫폼은 지원되지 않습니다."
#endif