.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) if(WIN32)
target_link_libraries(${PROJECT_NAME} PRIVATE ws2_32) target_link_libraries(${PROJECT_NAME} PRIVATE ws2_32)
endif() 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 target_include_directories(${PROJECT_NAME} PUBLIC
${CMAKE_CURRENT_SOURCE_DIR}/../include ${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") 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 COMMAND ${CMAKE_COMMAND} -E copy_if_different
"$<TARGET_FILE:spdlog>" "$<TARGET_FILE:spdlog>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>" "$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying spdlog DLL to output directory" COMMENT "Copying spdlog DLL/so to output directory"
) )
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_if_different COMMAND ${CMAKE_COMMAND} -E copy_if_different
"$<TARGET_FILE:jsoncpp_lib>" "$<TARGET_FILE:jsoncpp_lib>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>" "$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying jsoncpp DLL to output directory" COMMENT "Copying jsoncpp DLL/so to output directory"
) )
endif() 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() { int main() {
Chattr::TCPSocket sock; 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); sock.connect(serveraddr);
spdlog::info("Connection established from {}, {}", sock, (std::string)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) if(WIN32)
target_link_libraries(${PROJECT_NAME} PRIVATE ws2_32) target_link_libraries(${PROJECT_NAME} PRIVATE ws2_32)
endif() 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 target_include_directories(${PROJECT_NAME} PUBLIC
${CMAKE_CURRENT_SOURCE_DIR}/../include ${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") 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 COMMAND ${CMAKE_COMMAND} -E copy_if_different
"$<TARGET_FILE:spdlog>" "$<TARGET_FILE:spdlog>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>" "$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying spdlog DLL to output directory" COMMENT "Copying spdlog DLL/so to output directory"
) )
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_if_different COMMAND ${CMAKE_COMMAND} -E copy_if_different
"$<TARGET_FILE:jsoncpp_lib>" "$<TARGET_FILE:jsoncpp_lib>"
"$<TARGET_FILE_DIR:${PROJECT_NAME}>" "$<TARGET_FILE_DIR:${PROJECT_NAME}>"
COMMENT "Copying jsoncpp DLL to output directory" COMMENT "Copying jsoncpp DLL/so to output directory"
) )
endif() 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/ConfigManager.hpp"
#include "Utils/Thread.hpp" #include "Utils/Thread.hpp"
#include "Utils/StringTokenizer.hpp" #include "Utils/StringTokenizer.hpp"
#include "Session/Session.hpp"
#include "precomp.hpp" #include "precomp.hpp"
@@ -31,16 +32,33 @@ int main() {
sock.bind(&serveraddr.addr, serveraddr.length); sock.bind(&serveraddr.addr, serveraddr.length);
sock.listen(SOMAXCONN); sock.listen(SOMAXCONN);
#ifdef _WIN32
DWORD pid = GetCurrentProcessPid();
#elif __linux__
pid_t pid = getpid();
#endif
spdlog::info("PID : {}", pid);
while (true) { while (true) {
spdlog::info("Waiting for connection..."); spdlog::info("Waiting for connection...");
sock.accept(clientSock, clientAddr); sock.accept(clientSock, clientAddr);
Chattr::Thread thread_(_TCPClient, std::move(clientSock), clientAddr); Chattr::Thread thread_(_TCPClient, std::move(clientSock), clientAddr);
thread_.deatch(); thread_.detach();
} }
} }
void _TCPClient(Chattr::TCPSocket sock, Chattr::Address addr) { void _TCPClient(Chattr::TCPSocket sock, Chattr::Address addr) {
spdlog::info("Connection accepted! from: {}, {}", sock, (std::string)addr); spdlog::info("Connection accepted. [{}:{}]", sock, (std::string)addr);
Sleep(10000);
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; return INVALID_SOCKET;
} }
void Socket::move(const SOCKET __sock) void Socket::set(const SOCKET __sock) {
{
if (__sock == INVALID_SOCKET) if (__sock == INVALID_SOCKET)
log::critical("socket()"); log::critical("socket()");
@@ -53,14 +52,6 @@ void Socket::move(const SOCKET __sock)
valid_ = true; 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) { void Socket::bind(sockaddr *__addr) {
bind((struct sockaddr *)__addr, sizeof(sockaddr)); bind((struct sockaddr *)__addr, sizeof(sockaddr));
} }
@@ -89,7 +80,21 @@ void Socket::bind(sockaddr_in6 *__addr, socklen_t __len) {
bind((struct sockaddr *)__addr, __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; other_.valid_ = false;
sock_ = other_.sock_; sock_ = other_.sock_;
valid_ = true; valid_ = true;

View File

@@ -16,7 +16,7 @@ void TCPSocket::listen(int __n) {
} }
void TCPSocket::accept(TCPSocket& newSock, Address& __addr) { 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) if (newSock == INVALID_SOCKET)
log::critical("accept()"); log::critical("accept()");
} }
@@ -27,6 +27,18 @@ void TCPSocket::connect(Chattr::Address& serveraddr) {
log::critical("connect()"); 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" #include "Utils/StringTokenizer.hpp"
namespace Chattr { namespace Chattr {

View File

@@ -14,7 +14,7 @@ void Thread::join() {
#endif #endif
} }
void Thread::deatch() { void Thread::detach() {
detached = true; 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(); void destruct();
operator SOCKET() const; operator SOCKET() const;
void move(const SOCKET); void set(const SOCKET);
Socket& move();
void bind(sockaddr *__addr); void bind(sockaddr *__addr);
void bind(sockaddr *__addr, socklen_t __len); void bind(sockaddr *__addr, socklen_t __len);
@@ -29,6 +28,9 @@ public:
void bind(sockaddr_in6 *__addr); void bind(sockaddr_in6 *__addr);
void bind(sockaddr_in6 *__addr, socklen_t __len); 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(const Socket&) = delete;
Socket(Socket&&); Socket(Socket&&);
Socket& operator=(const Socket&) = delete; Socket& operator=(const Socket&) = delete;

View File

@@ -11,6 +11,8 @@ public:
void listen(int __n); void listen(int __n);
void accept(TCPSocket& newSock, Address& addr); void accept(TCPSocket& newSock, Address& addr);
void connect(Chattr::Address& serveraddr); 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(); ~Thread();
void join(); void join();
void deatch(); void detach();
private: private:
#ifdef _WIN32 #ifdef _WIN32

View File

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