From 64596d344cdb1a1448d3456433fadb6550118cc8 Mon Sep 17 00:00:00 2001 From: Exynox Date: Wed, 9 Mar 2022 21:30:51 +0200 Subject: [PATCH] WIP: rewrite the network stack to use libevent --- common/length.h | 4 +- common/service.h | 1 - db/CMakeLists.txt | 31 +- db/src/ClientManager.cpp | 222 +++++---- db/src/ClientManager.h | 28 +- db/src/DBManager.h | 2 - db/src/Main.cpp | 7 - db/src/NetBase.cpp | 54 -- db/src/NetBase.h | 25 - db/src/Peer.cpp | 18 +- db/src/Peer.h | 2 - db/src/PeerBase.cpp | 235 +++------ db/src/PeerBase.h | 61 +-- game/src/char_battle.cpp | 4 +- game/src/char_item.cpp | 16 +- game/src/desc.cpp | 14 - game/src/desc.h | 4 - game/src/desc_manager.cpp | 4 +- game/src/event.cpp | 16 +- game/src/event_queue.cpp | 2 +- game/src/group_text_parse_tree.h | 16 +- game/src/input.h | 22 - game/src/input_udp.cpp | 194 ------- game/src/locale_service.cpp | 64 +-- game/src/main.cpp | 38 -- game/src/packet.h | 8 - game/src/packet_info.h | 8 - game/src/questlua_npc.cpp | 6 +- game/src/text_file_loader.cpp | 110 ++-- game/src/utils.cpp | 2 +- libsql/CMakeLists.txt | 14 +- libthecore/CMakeLists.txt | 8 +- libthecore/include/fdwatch.h | 95 ---- libthecore/include/{signal.h => signals.h} | 0 libthecore/include/socket.h | 45 -- libthecore/include/stdafx.h | 120 +---- libthecore/include/typedef.h | 32 +- libthecore/src/fdwatch.cpp | 461 ----------------- libthecore/src/log.cpp | 2 +- libthecore/src/main.cpp | 6 +- libthecore/src/{signal.cpp => signals.cpp} | 2 +- libthecore/src/socket.cpp | 555 --------------------- libthecore/src/utils.cpp | 6 +- 43 files changed, 415 insertions(+), 2149 deletions(-) delete mode 100644 db/src/NetBase.cpp delete mode 100644 db/src/NetBase.h delete mode 100644 game/src/input_udp.cpp delete mode 100644 libthecore/include/fdwatch.h rename libthecore/include/{signal.h => signals.h} (100%) delete mode 100644 libthecore/include/socket.h delete mode 100644 libthecore/src/fdwatch.cpp rename libthecore/src/{signal.cpp => signals.cpp} (98%) delete mode 100644 libthecore/src/socket.cpp diff --git a/common/length.h b/common/length.h index 7f57a1e..df3853f 100644 --- a/common/length.h +++ b/common/length.h @@ -4,8 +4,8 @@ #define WORD_MAX 0xffff enum EMisc { - MAX_HOST_LENGTH = 15, - IP_ADDRESS_LENGTH = 15, + MAX_HOST_LENGTH = 253, + IP_ADDRESS_LENGTH = INET6_ADDRSTRLEN > INET_ADDRSTRLEN ? INET6_ADDRSTRLEN : INET_ADDRSTRLEN, LOGIN_MAX_LEN = 30, PASSWD_MAX_LEN = 16, PLAYER_PER_ACCOUNT = 4, diff --git a/common/service.h b/common/service.h index d35e14a..f4cd567 100644 --- a/common/service.h +++ b/common/service.h @@ -4,5 +4,4 @@ #define _IMPROVED_PACKET_ENCRYPTION_ // ÆÐŶ ¾Ïȣȭ °³¼± //#define __AUCTION__ #define __PET_SYSTEM__ -#define __UDP_BLOCK__ #endif diff --git a/db/CMakeLists.txt b/db/CMakeLists.txt index 0f131e5..58bfe42 100644 --- a/db/CMakeLists.txt +++ b/db/CMakeLists.txt @@ -11,27 +11,20 @@ include_directories(${PROJECT_BINARY_DIR}/src/) include_directories(src/) -# Find dependencies -find_package(libmysql REQUIRED) -find_package(Boost REQUIRED) - add_executable(${PROJECT_NAME} ${sources}) -# Link dependencies if found -if (libmysql_FOUND) - target_link_libraries (${PROJECT_NAME} ${MYSQL_LIBRARIES}) -endif (libmysql_FOUND) +# Find dependencies +find_package(Boost REQUIRED) +include_directories(${Boost_INCLUDE_DIRS}) +target_link_libraries (${PROJECT_NAME} PRIVATE ${Boost_LIBRARIES} ${Boost_SYSTEM_LIBRARY}) -if (Boost_FOUND) - include_directories(${Boost_INCLUDE_DIRS}) - target_link_libraries (${PROJECT_NAME} ${Boost_LIBRARIES} ${Boost_SYSTEM_LIBRARY}) -endif (Boost_FOUND) +# Pthreads +set(THREADS_PREFER_PTHREAD_FLAG ON) +find_package(Threads REQUIRED) +target_link_libraries(${PROJECT_NAME} PRIVATE Threads::Threads) -if (${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD") - # Pthreads - set(THREADS_PREFER_PTHREAD_FLAG ON) - find_package (Threads REQUIRED) - target_link_libraries (${PROJECT_NAME} Threads::Threads) -endif (${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD") +# Libevent +find_package(Libevent CONFIG REQUIRED) +target_link_libraries(${PROJECT_NAME} PRIVATE libevent::core libevent::extra libevent::pthreads) -target_link_libraries(${PROJECT_NAME} libpoly libsql libthecore) +target_link_libraries(${PROJECT_NAME} PRIVATE libpoly libsql libthecore) diff --git a/db/src/ClientManager.cpp b/db/src/ClientManager.cpp index 17cbcd2..a8dfb74 100644 --- a/db/src/ClientManager.cpp +++ b/db/src/ClientManager.cpp @@ -1,4 +1,3 @@ - #include "stdafx.h" #include @@ -41,6 +40,71 @@ CPacketInfo g_item_info; int g_item_count = 0; int g_query_count[2]; +static void AcceptConnection( + evconnlistener* listener, + evutil_socket_t fd, + sockaddr* address, + int socklen, + void* ctx) +{ + // We got a new connection! We have to create a new peer. + auto* clientManager = (CClientManager*) ctx; + + // Create a new buffer for the peer + event_base *base = evconnlistener_get_base(listener); + bufferevent *bev = bufferevent_socket_new(base, fd, BEV_OPT_CLOSE_ON_FREE); + + // Create a new peer + CPeer* peer = clientManager->AddPeer(bev, address); + + // Set the event handlers for this peer + bufferevent_setcb(bev, ReadHandler, WriteHandler, EventHandler, peer); + + // Enable the events + bufferevent_enable(bev, EV_READ|EV_WRITE); +} + +static void AcceptError(evconnlistener *listener, void *ctx) { + struct event_base *base = evconnlistener_get_base(listener); + int err = EVUTIL_SOCKET_ERROR(); + fprintf(stderr, "Got an error %d (%s) on the listener. " + "Shutting down.\n", err, evutil_socket_error_to_string(err)); + + event_base_loopexit(base, NULL); +} + +static void ReadHandler(bufferevent *bev, void *ctx) { + auto* peer = (CPeer*) ctx; + + if (peer == CClientManager::Instance().GetAuthPeer()) + if (g_log) + sys_log(0, "AUTH_PEER_READ: size %d", peer->GetRecvLength()); + + CClientManager::Instance().ProcessPackets(peer); +} + +static void WriteHandler(bufferevent *bev, void *ctx) { + auto* peer = (CPeer*) ctx; + + if (peer == CClientManager::Instance().GetAuthPeer()) + if (g_log) + sys_log(0, "AUTH_PEER_WRITE: size %d", peer->GetSendLength()); +} + +static void EventHandler(bufferevent *bev, short events, void *ctx) { + auto* peer = (CPeer*) ctx; + + if (events & BEV_EVENT_ERROR) + sys_err("PEER libevent error, handle: %d", peer->GetHandle()); + + if (events & BEV_EVENT_EOF) + sys_log(0, "PEER disconnected: handle %d", peer->GetHandle()); + + // Either the socket was closed or an error occured, therefore we can disconnect this peer. + if (events & (BEV_EVENT_EOF | BEV_EVENT_ERROR)) + CClientManager::Instance().RemovePeer(peer); +} + CClientManager::CClientManager() : m_pkAuthPeer(NULL), m_iPlayerIDStart(0), @@ -51,7 +115,7 @@ CClientManager::CClientManager() : m_pShopTable(NULL), m_iRefineTableSize(0), m_pRefineTable(NULL), - m_bShutdowned(FALSE), + m_bShutdowned(false), m_iCacheFlushCount(0), m_iCacheFlushCountLimit(200) { @@ -75,16 +139,22 @@ void CClientManager::SetPlayerIDStart(int iIDStart) void CClientManager::Destroy() { m_mChannelStatus.clear(); - for (itertype(m_peerList) i = m_peerList.begin(); i != m_peerList.end(); ++i) - (*i)->Destroy(); + // Close the peer connections and empty the peer list + for (auto &peer: m_peerList) + peer->Destroy(); m_peerList.clear(); - if (m_fdAccept > 0) - { - socket_close(m_fdAccept); - m_fdAccept = -1; - } + // Free the libevent resources + if (m_listener) { + evconnlistener_free(m_listener); + m_listener = nullptr; + } + + if (m_base) { + event_base_free(m_base); + m_base = nullptr; + } } bool CClientManager::Initialize() @@ -124,16 +194,33 @@ bool CClientManager::Initialize() if (!CConfig::instance().GetValue("BIND_IP", szBindIP, 128)) strncpy(szBindIP, "0", sizeof(szBindIP)); - m_fdAccept = socket_tcp_bind(szBindIP, tmpValue); + // Create a new libevent base and listen for new connections + event_enable_debug_mode(); + m_base = event_base_new(); + if (!m_base) { + sys_err("Libevent base initialization FAILED!"); + return false; + } - if (m_fdAccept < 0) - { - perror("socket"); - return false; - } + sockaddr_in sin = {}; - sys_log(0, "ACCEPT_HANDLE: %u", m_fdAccept); - fdwatch_add_fd(m_fdWatcher, m_fdAccept, NULL, FDW_READ, false); + /* This is an INET address */ + sin.sin_family = AF_INET; + + sin.sin_addr.s_addr = inet_addr(szBindIP); + sin.sin_port = htons(tmpValue); + + m_listener = evconnlistener_new_bind( + m_base, + AcceptConnection, this, + LEV_OPT_CLOSE_ON_FREE|LEV_OPT_REUSEABLE, -1, + (const sockaddr*)&sin, sizeof(sin) + ); + if (!m_listener) { + sys_err("Libevent listener initialization FAILED!"); + return false; + } + evconnlistener_set_error_cb(m_listener, AcceptError); if (!CConfig::instance().GetValue("BACKUP_LIMIT_SEC", &tmpValue)) tmpValue = 600; @@ -242,7 +329,7 @@ void CClientManager::MainLoop() void CClientManager::Quit() { - m_bShutdowned = TRUE; + m_bShutdowned = true; } void CClientManager::QUERY_BOOT(CPeer* peer, TPacketGDBoot * p) @@ -2745,14 +2832,17 @@ void CClientManager::ProcessPackets(CPeer * peer) peer->RecvEnd(i); } -void CClientManager::AddPeer(socket_t fd) +CPeer * CClientManager::AddPeer(bufferevent* bufev, sockaddr* addr) { - CPeer * pPeer = new CPeer; + auto* pPeer = new CPeer; - if (pPeer->Accept(fd)) - m_peerList.push_front(pPeer); - else - delete pPeer; + if (!pPeer->Accept(bufev, addr)) { + delete pPeer; + return nullptr; + } + + m_peerList.push_front(pPeer); + return pPeer; } void CClientManager::RemovePeer(CPeer * pPeer) @@ -2807,6 +2897,11 @@ CPeer * CClientManager::GetPeer(IDENT ident) return NULL; } +CPeer * CClientManager::GetAuthPeer() +{ + return m_pkAuthPeer; +} + CPeer * CClientManager::GetAnyPeer() { if (m_peerList.empty()) @@ -3132,83 +3227,8 @@ int CClientManager::Process() } } - int num_events = fdwatch(m_fdWatcher, 0); - int idx; - CPeer * peer; - - for (idx = 0; idx < num_events; ++idx) // ÀÎDz - { - peer = (CPeer *) fdwatch_get_client_data(m_fdWatcher, idx); - - if (!peer) - { - if (fdwatch_check_event(m_fdWatcher, m_fdAccept, idx) == FDW_READ) - { - AddPeer(m_fdAccept); - fdwatch_clear_event(m_fdWatcher, m_fdAccept, idx); - } - else - { - sys_err("FDWATCH: peer null in event: ident %d", fdwatch_get_ident(m_fdWatcher, idx)); - } - - continue; - } - - switch (fdwatch_check_event(m_fdWatcher, peer->GetFd(), idx)) - { - case FDW_READ: - if (peer->Recv() < 0) - { - sys_err("Recv failed"); - RemovePeer(peer); - } - else - { - if (peer == m_pkAuthPeer) - if (g_log) - sys_log(0, "AUTH_PEER_READ: size %d", peer->GetRecvLength()); - - ProcessPackets(peer); - } - break; - - case FDW_WRITE: - if (peer == m_pkAuthPeer) - if (g_log) - sys_log(0, "AUTH_PEER_WRITE: size %d", peer->GetSendLength()); - - if (peer->Send() < 0) - { - sys_err("Send failed"); - RemovePeer(peer); - } - - break; - - case FDW_EOF: - RemovePeer(peer); - break; - - default: - sys_err("fdwatch_check_fd returned unknown result"); - RemovePeer(peer); - break; - } - } - -#ifdef __WIN32__ - if (_kbhit()) { - int c = _getch(); - switch (c) { - case 0x1b: // Esc - return 0; // shutdown - break; - default: - break; - } - } -#endif + // Process network events + event_base_loop(m_base, EVLOOP_NONBLOCK); VCardProcess(); return 1; diff --git a/db/src/ClientManager.h b/db/src/ClientManager.h index 82bf4e4..6cc2d70 100644 --- a/db/src/ClientManager.h +++ b/db/src/ClientManager.h @@ -1,10 +1,12 @@ -// vim:ts=8 sw=4 #ifndef __INC_CLIENTMANAGER_H__ #define __INC_CLIENTMANAGER_H__ #include #include +#include +#include + #include #include #include @@ -28,7 +30,13 @@ class CPacketInfo size_t CreatePlayerSaveQuery(char * pszQuery, size_t querySize, TPlayerTable * pkTab); -class CClientManager : public CNetBase, public singleton +static void AcceptConnection(evconnlistener *listener, evutil_socket_t fd, sockaddr *address, int socklen, void *ctx); +static void AcceptError(evconnlistener *listener, void *ctx); +static void ReadHandler(bufferevent *bev, void *ctx); +static void WriteHandler(bufferevent *bev, void *ctx); +static void EventHandler(bufferevent *bev, short events, void *ctx); + +class CClientManager : public singleton { public: typedef std::list TPeerList; @@ -165,6 +173,13 @@ class CClientManager : public CNetBase, public singleton char* GetCommand(char* str); //µ¶Àϼ±¹°±â´É¿¡¼­ ¸í·É¾î ¾ò´Â ÇÔ¼ö void ItemAward(CPeer * peer, char* login); //µ¶ÀÏ ¼±¹° ±â´É + CPeer * AddPeer(bufferevent* bufev, sockaddr* addr); + void RemovePeer(CPeer * pPeer); + CPeer * GetPeer(IDENT ident); + CPeer * GetAuthPeer(); + + void ProcessPackets(CPeer * peer); + protected: void Destroy(); @@ -190,17 +205,11 @@ class CClientManager : public CNetBase, public singleton bool MirrorMobTableIntoDB(); bool MirrorItemTableIntoDB(); - void AddPeer(socket_t fd); - void RemovePeer(CPeer * pPeer); - CPeer * GetPeer(IDENT ident); - int AnalyzeQueryResult(SQLMsg * msg); int AnalyzeErrorMsg(CPeer * peer, SQLMsg * msg); int Process(); - void ProcessPackets(CPeer * peer); - CLoginData * GetLoginData(DWORD dwKey); CLoginData * GetLoginDataByLogin(const char * c_pszLogin); CLoginData * GetLoginDataByAID(DWORD dwAID); @@ -386,7 +395,8 @@ class CClientManager : public CNetBase, public singleton private: int m_looping; - socket_t m_fdAccept; // Á¢¼Ó ¹Þ´Â ¼ÒÄÏ + event_base * m_base; + evconnlistener * m_listener; TPeerList m_peerList; CPeer * m_pkAuthPeer; diff --git a/db/src/DBManager.h b/db/src/DBManager.h index be4b314..7129e8b 100644 --- a/db/src/DBManager.h +++ b/db/src/DBManager.h @@ -5,8 +5,6 @@ // µðºñ Ä¿³Ø¼Ç Ŭ·¡½ºÀÇ ¸ñÀûÀº... µðºñ¿¡ Á¢¼ÓÇؼ­ Äõ¸®º¸³»°í °á°ú ¹Þ¾Æ¿À´Â // ¸ðµç ÀϵéÀ» ó¸®ÇÑ´Ù. // ÄÚµå by ²¿ºØ Èķα׷¡¸Ó ¾Æ³ë¾Æ~ = _=)b -#include - #include #define SQL_SAFE_LENGTH(size) (size * 2 + 1) diff --git a/db/src/Main.cpp b/db/src/Main.cpp index 461782e..6cc69e7 100644 --- a/db/src/Main.cpp +++ b/db/src/Main.cpp @@ -70,7 +70,6 @@ int main() #endif CConfig Config; - CNetPoller poller; CDBManager DBManager; CClientManager ClientManager; PlayerHB player_hb; @@ -369,12 +368,6 @@ int Start() sys_err("SQL_HOTBACKUP not configured"); return false; } - - if (!CNetPoller::instance().Create()) - { - sys_err("Cannot create network poller"); - return false; - } sys_log(0, "ClientManager initialization.. "); diff --git a/db/src/NetBase.cpp b/db/src/NetBase.cpp deleted file mode 100644 index 34874d4..0000000 --- a/db/src/NetBase.cpp +++ /dev/null @@ -1,54 +0,0 @@ -#include "stdafx.h" -#include "NetBase.h" -#include "Config.h" -#include "ClientManager.h" - -LPFDWATCH CNetBase::m_fdWatcher = NULL; - -CNetBase::CNetBase() -{ -} - -CNetBase::~CNetBase() -{ -} - -CNetPoller::CNetPoller() -{ -} - -CNetPoller::~CNetPoller() -{ - Destroy(); -} - -bool CNetPoller::Create() -{ - sys_log(1, "NetPoller::Create()"); - - if (m_fdWatcher) - return true; - - m_fdWatcher = fdwatch_new(512); - - if (!m_fdWatcher) - { - Destroy(); - return false; - } - - return true; -} - -void CNetPoller::Destroy() -{ - sys_log(1, "NetPoller::Destroy()"); - - if (m_fdWatcher) - { - fdwatch_delete(m_fdWatcher); - m_fdWatcher = NULL; - } - - thecore_destroy(); -} diff --git a/db/src/NetBase.h b/db/src/NetBase.h deleted file mode 100644 index 00b1f84..0000000 --- a/db/src/NetBase.h +++ /dev/null @@ -1,25 +0,0 @@ -// vim: ts=8 sw=4 -#ifndef __INC_NETWORKBASE_H__ -#define __INC_NETWORKBASE_H__ - -class CNetBase -{ - public: - CNetBase(); - virtual ~CNetBase(); - - protected: - static LPFDWATCH m_fdWatcher; -}; - -class CNetPoller : public CNetBase, public singleton -{ - public: - CNetPoller(); - virtual ~CNetPoller(); - - bool Create(); - void Destroy(); -}; - -#endif diff --git a/db/src/Peer.cpp b/db/src/Peer.cpp index 18f0838..a7f3193 100644 --- a/db/src/Peer.cpp +++ b/db/src/Peer.cpp @@ -29,13 +29,7 @@ void CPeer::OnAccept() static DWORD current_handle = 0; m_dwHandle = ++current_handle; - sys_log(0, "Connection accepted. (host: %s handle: %u fd: %d)", m_host, m_dwHandle, m_fd); -} - -void CPeer::OnConnect() -{ - sys_log(0, "Connection established. (host: %s handle: %u fd: %d)", m_host, m_dwHandle, m_fd); - m_state = STATE_PLAYING; + sys_log(0, "Connection accepted. (host: %s handle: %u)", m_host, m_dwHandle); } void CPeer::OnClose() @@ -72,7 +66,7 @@ bool CPeer::PeekPacket(int & iBytesProceed, BYTE & header, DWORD & dwHandle, DWO if (GetRecvLength() < iBytesProceed + 9) return false; - const char * buf = (const char *) GetRecvBuffer(); + const char * buf = (const char *) GetRecvBuffer(iBytesProceed + 9); buf += iBytesProceed; header = *(buf++); @@ -114,14 +108,6 @@ void CPeer::EncodeReturn(BYTE header, DWORD dwHandle) EncodeHeader(header, dwHandle, 0); } -int CPeer::Send() -{ - if (m_state == STATE_CLOSE) - return -1; - - return (CPeerBase::Send()); -} - void CPeer::SetP2PPort(WORD wPort) { m_wP2PPort = wPort; diff --git a/db/src/Peer.h b/db/src/Peer.h index bf80cf7..8a05590 100644 --- a/db/src/Peer.h +++ b/db/src/Peer.h @@ -9,7 +9,6 @@ class CPeer : public CPeerBase protected: virtual void OnAccept(); virtual void OnClose(); - virtual void OnConnect(); public: #pragma pack(1) @@ -34,7 +33,6 @@ class CPeer : public CPeerBase void EncodeReturn(BYTE header, DWORD dwHandle); void ProcessInput(); - int Send(); DWORD GetHandle(); DWORD GetUserCount(); diff --git a/db/src/PeerBase.cpp b/db/src/PeerBase.cpp index a936f41..a037f9d 100644 --- a/db/src/PeerBase.cpp +++ b/db/src/PeerBase.cpp @@ -1,7 +1,9 @@ #include "stdafx.h" #include "PeerBase.h" -CPeerBase::CPeerBase() : m_fd(INVALID_SOCKET), m_BytesRemain(0), m_outBuffer(NULL), m_inBuffer(NULL) +#include + +CPeerBase::CPeerBase() : m_bufferevent(nullptr) { } @@ -10,83 +12,53 @@ CPeerBase::~CPeerBase() Destroy(); } -void CPeerBase::Disconnect() -{ - if (m_fd != INVALID_SOCKET) - { - fdwatch_del_fd(m_fdWatcher, m_fd); - - socket_close(m_fd); - m_fd = INVALID_SOCKET; - } -} - void CPeerBase::Destroy() { - Disconnect(); - - if (m_outBuffer) - { - buffer_delete(m_outBuffer); - m_outBuffer = NULL; - } - - if (m_inBuffer) - { - buffer_delete(m_inBuffer); - m_inBuffer = NULL; - } + if (m_bufferevent) { + bufferevent_free(m_bufferevent); + m_bufferevent = nullptr; + } } -bool CPeerBase::Accept(socket_t fd_accept) +bool CPeerBase::Accept(bufferevent* bufev, sockaddr* addr) { - struct sockaddr_in peer; + if (!bufev) { + sys_err("Cannot accept empty bufferevent!"); + return false; + } - if ((m_fd = socket_accept(fd_accept, &peer)) == INVALID_SOCKET) - { - Destroy(); - return false; - } + if (m_bufferevent != nullptr) { + sys_err("Peer is already initialized"); + return false; + } - //socket_block(m_fd); - socket_sndbuf(m_fd, 233016); - socket_rcvbuf(m_fd, 233016); + // Save the bufferevent + m_bufferevent = bufev; - strncpy(m_host, inet_ntoa(peer.sin_addr), sizeof(m_host)); - m_outBuffer = buffer_new(DEFAULT_PACKET_BUFFER_SIZE); - m_inBuffer = buffer_new(MAX_INPUT_LEN); + // Get the address of the conected peer + sockaddr_in* peer; + sockaddr_in6* peer6; - if (!m_outBuffer || !m_inBuffer) - { - Destroy(); - return false; - } + switch (addr->sa_family) { + case AF_INET: + peer = (sockaddr_in*) addr; + inet_ntop(AF_INET, &(peer->sin_addr), m_host, INET_ADDRSTRLEN); + break; - fdwatch_add_fd(m_fdWatcher, m_fd, this, FDW_READ, false); + case AF_INET6: + peer6 = (sockaddr_in6*) addr; + inet_ntop(AF_INET, &(peer6->sin6_addr), m_host, INET6_ADDRSTRLEN); + break; + default: + break; + } + + // Trigger the OnAccept event OnAccept(); - sys_log(0, "ACCEPT FROM %s", inet_ntoa(peer.sin_addr)); - return true; -} -bool CPeerBase::Connect(const char* host, WORD port) -{ - strncpy(m_host, host, sizeof(m_host)); + sys_log(0, "ACCEPT FROM %s", m_host); - if ((m_fd = socket_connect(host, port)) == INVALID_SOCKET) - return false; - - m_outBuffer = buffer_new(DEFAULT_PACKET_BUFFER_SIZE); - - if (!m_outBuffer) - { - Destroy(); - return false; - } - - fdwatch_add_fd(m_fdWatcher, m_fd, this, FDW_READ, false); - - OnConnect(); return true; } @@ -97,118 +69,77 @@ void CPeerBase::Close() void CPeerBase::EncodeBYTE(BYTE b) { - if (!m_outBuffer) - { - sys_err("Not ready to write"); - return; - } - - buffer_write(m_outBuffer, &b, 1); - fdwatch_add_fd(m_fdWatcher, m_fd, this, FDW_WRITE, true); + Encode(&b, sizeof(b)); } void CPeerBase::EncodeWORD(WORD w) { - if (!m_outBuffer) - { - sys_err("Not ready to write"); - return; - } - - buffer_write(m_outBuffer, &w, 2); - fdwatch_add_fd(m_fdWatcher, m_fd, this, FDW_WRITE, true); + Encode(&w, sizeof(w)); } void CPeerBase::EncodeDWORD(DWORD dw) { - if (!m_outBuffer) + Encode(&dw, sizeof(dw)); +} + +void CPeerBase::Encode(const void* data, size_t size) +{ + if (!m_bufferevent) { - sys_err("Not ready to write"); + sys_err("Bufferevent not ready!"); return; } - buffer_write(m_outBuffer, &dw, 4); - fdwatch_add_fd(m_fdWatcher, m_fd, this, FDW_WRITE, true); + if(bufferevent_write(m_bufferevent, data, size) != 0) { + sys_err("Buffer write error!"); + return; + } } -void CPeerBase::Encode(const void* data, DWORD size) +void CPeerBase::RecvEnd(size_t proceed_bytes) { - if (!m_outBuffer) - { - sys_err("Not ready to write"); - return; - } + if (!m_bufferevent) + { + sys_err("Bufferevent not ready!"); + return; + } - buffer_write(m_outBuffer, data, size); - fdwatch_add_fd(m_fdWatcher, m_fd, this, FDW_WRITE, true); + evbuffer *input = bufferevent_get_input(m_bufferevent); + evbuffer_drain(input, proceed_bytes); } -int CPeerBase::Recv() +size_t CPeerBase::GetRecvLength() { - if (!m_inBuffer) - { - sys_err("input buffer nil"); - return -1; - } + if (!m_bufferevent) + { + sys_err("Bufferevent not ready!"); + return 0; + } - buffer_adjust_size(m_inBuffer, MAX_INPUT_LEN >> 2); - int bytes_to_read = buffer_has_space(m_inBuffer); - ssize_t bytes_read = socket_read(m_fd, (char *) buffer_write_peek(m_inBuffer), bytes_to_read); - - if (bytes_read < 0) - { - sys_err("socket_read failed %s", strerror(errno)); - return -1; - } - else if (bytes_read == 0) - return 0; - - buffer_write_proceed(m_inBuffer, bytes_read); - m_BytesRemain = buffer_size(m_inBuffer); - return 1; + evbuffer *input = bufferevent_get_input(m_bufferevent); + return evbuffer_get_length(input); } -void CPeerBase::RecvEnd(int proceed_bytes) +const void * CPeerBase::GetRecvBuffer(ssize_t ensure_bytes) { - buffer_read_proceed(m_inBuffer, proceed_bytes); - m_BytesRemain = buffer_size(m_inBuffer); + if (!m_bufferevent) + { + sys_err("Bufferevent not ready!"); + return nullptr; + } + + evbuffer *input = bufferevent_get_input(m_bufferevent); + return evbuffer_pullup(input, ensure_bytes); } -int CPeerBase::GetRecvLength() +size_t CPeerBase::GetSendLength() { - return m_BytesRemain; -} - -const void * CPeerBase::GetRecvBuffer() -{ - return buffer_read_peek(m_inBuffer); -} - -int CPeerBase::GetSendLength() -{ - return buffer_size(m_outBuffer); -} - -int CPeerBase::Send() -{ - if (buffer_size(m_outBuffer) <= 0) - return 0; - - int iBufferLeft = fdwatch_get_buffer_size(m_fdWatcher, m_fd); - int iBytesToWrite = MIN(iBufferLeft, buffer_size(m_outBuffer)); - - if (iBytesToWrite == 0) - return 0; - - int result = socket_write(m_fd, (const char *) buffer_read_peek(m_outBuffer), iBytesToWrite); - - if (result == 0) - { - buffer_read_proceed(m_outBuffer, iBytesToWrite); - - if (buffer_size(m_outBuffer) != 0) - fdwatch_add_fd(m_fdWatcher, m_fd, this, FDW_WRITE, true); - } - - return (result); + if (!m_bufferevent) + { + sys_err("Bufferevent not ready!"); + return 0; + } + + evbuffer *output = bufferevent_get_output(m_bufferevent); + return evbuffer_get_length(output); } diff --git a/db/src/PeerBase.h b/db/src/PeerBase.h index 3d192c9..92c3ca2 100644 --- a/db/src/PeerBase.h +++ b/db/src/PeerBase.h @@ -1,61 +1,40 @@ -// vim: ts=8 sw=4 #ifndef __INC_PEERBASE_H__ #define __INC_PEERBASE_H__ -#include "NetBase.h" +#include -class CPeerBase : public CNetBase -{ - public: - enum - { - MAX_HOST_LENGTH = 30, - MAX_INPUT_LEN = 1024 * 1024 * 2, - DEFAULT_PACKET_BUFFER_SIZE = 1024 * 1024 * 2 - }; - - protected: +class CPeerBase { +protected: virtual void OnAccept() = 0; - virtual void OnConnect() = 0; virtual void OnClose() = 0; - public: - bool Accept(socket_t accept_fd); - bool Connect(const char* host, WORD port); - void Close(); +public: + bool Accept(bufferevent* bufev, sockaddr* addr); + void Close(); - public: +public: CPeerBase(); virtual ~CPeerBase(); - void Disconnect(); - void Destroy(); + void Destroy(); - socket_t GetFd() { return m_fd; } + bufferevent * GetBufferevent() { return m_bufferevent; } - void EncodeBYTE(BYTE b); - void EncodeWORD(WORD w); - void EncodeDWORD(DWORD dw); - void Encode(const void* data, DWORD size); - int Send(); + void EncodeBYTE(BYTE b); + void EncodeWORD(WORD w); + void EncodeDWORD(DWORD dw); + void Encode(const void* data, size_t size); + void RecvEnd(size_t proceed_bytes); + size_t GetRecvLength(); + const void * GetRecvBuffer(ssize_t ensure_bytes); - int Recv(); - void RecvEnd(int proceed_bytes); - int GetRecvLength(); - const void * GetRecvBuffer(); - - int GetSendLength(); + size_t GetSendLength(); const char * GetHost() { return m_host; } - protected: - char m_host[MAX_HOST_LENGTH + 1]; - socket_t m_fd; - - private: - int m_BytesRemain; - LPBUFFER m_outBuffer; - LPBUFFER m_inBuffer; +protected: + char m_host[IP_ADDRESS_LENGTH + 1]; + bufferevent * m_bufferevent; }; #endif diff --git a/game/src/char_battle.cpp b/game/src/char_battle.cpp index 0076bb9..41aa5dd 100644 --- a/game/src/char_battle.cpp +++ b/game/src/char_battle.cpp @@ -2047,7 +2047,7 @@ bool CHARACTER::Damage(LPCHARACTER pAttacker, int dam, EDamageType type) // retu } else { - // Á¤½Å·ÂÀÌ ¸ðÀÚ¶ó¼­ ÇÇ°¡ ´õ ±ï¿©¾ßÇÒ‹š + // Á¤½Å·ÂÀÌ ¸ðÀÚ¶ó¼­ ÇÇ°¡ ´õ ±ï¿©¾ßÇÒ?? PointChange(POINT_SP, -GetSP()); dam -= iSP * 100 / MAX(GetPoint(POINT_MANASHIELD), 1); } @@ -3132,7 +3132,7 @@ class CFuncShoot break; } - m_bSucceed = TRUE; + m_bSucceed = true; } }; diff --git a/game/src/char_item.cpp b/game/src/char_item.cpp index f49fe40..079d739 100644 --- a/game/src/char_item.cpp +++ b/game/src/char_item.cpp @@ -2282,7 +2282,7 @@ bool CHARACTER::UseItemEx(LPITEM item, TItemPos DestCell) { PointChange(POINT_HP, item->GetValue(0) * (100 + GetPoint(POINT_POTION_BONUS)) / 100); EffectPacket(SE_HPUP_RED); - used = TRUE; + used = true; } } @@ -2292,7 +2292,7 @@ bool CHARACTER::UseItemEx(LPITEM item, TItemPos DestCell) { PointChange(POINT_SP, item->GetValue(1) * (100 + GetPoint(POINT_POTION_BONUS)) / 100); EffectPacket(SE_SPUP_BLUE); - used = TRUE; + used = true; } } @@ -2302,7 +2302,7 @@ bool CHARACTER::UseItemEx(LPITEM item, TItemPos DestCell) { PointChange(POINT_HP, item->GetValue(3) * GetMaxHP() / 100); EffectPacket(SE_HPUP_RED); - used = TRUE; + used = true; } } @@ -2312,7 +2312,7 @@ bool CHARACTER::UseItemEx(LPITEM item, TItemPos DestCell) { PointChange(POINT_SP, item->GetValue(4) * GetMaxSP() / 100); EffectPacket(SE_SPUP_BLUE); - used = TRUE; + used = true; } } @@ -4133,7 +4133,7 @@ bool CHARACTER::UseItemEx(LPITEM item, TItemPos DestCell) { PointChange(POINT_HP, item->GetValue(0) * (100 + GetPoint(POINT_POTION_BONUS)) / 100); EffectPacket(SE_HPUP_RED); - used = TRUE; + used = true; } } @@ -4143,7 +4143,7 @@ bool CHARACTER::UseItemEx(LPITEM item, TItemPos DestCell) { PointChange(POINT_SP, item->GetValue(1) * (100 + GetPoint(POINT_POTION_BONUS)) / 100); EffectPacket(SE_SPUP_BLUE); - used = TRUE; + used = true; } } @@ -4153,7 +4153,7 @@ bool CHARACTER::UseItemEx(LPITEM item, TItemPos DestCell) { PointChange(POINT_HP, item->GetValue(3) * GetMaxHP() / 100); EffectPacket(SE_HPUP_RED); - used = TRUE; + used = true; } } @@ -4163,7 +4163,7 @@ bool CHARACTER::UseItemEx(LPITEM item, TItemPos DestCell) { PointChange(POINT_SP, item->GetValue(4) * GetMaxSP() / 100); EffectPacket(SE_SPUP_BLUE); - used = TRUE; + used = true; } } diff --git a/game/src/desc.cpp b/game/src/desc.cpp index 90c8ebd..196b11c 100644 --- a/game/src/desc.cpp +++ b/game/src/desc.cpp @@ -61,7 +61,6 @@ void DESC::Initialize() memset( &m_accountTable, 0, sizeof(m_accountTable) ); memset( &m_SockAddr, 0, sizeof(m_SockAddr) ); - memset( &m_UDPSockAddr, 0, sizeof(m_UDPSockAddr) ); m_pLogFile = NULL; @@ -582,19 +581,6 @@ void DESC::BindAccountTable(TAccountTable * pAccountTable) DESC_MANAGER::instance().ConnectAccount(m_accountTable.login, this); } -void DESC::UDPGrant(const struct sockaddr_in & c_rSockAddr) -{ - m_UDPSockAddr = c_rSockAddr; - - TPacketGCBindUDP pack; - - pack.header = HEADER_GC_BINDUDP; - pack.addr = m_UDPSockAddr.sin_addr.s_addr; - pack.port = m_UDPSockAddr.sin_port; - - Packet(&pack, sizeof(TPacketGCBindUDP)); -} - void DESC::Log(const char * format, ...) { if (!m_pLogFile) diff --git a/game/src/desc.h b/game/src/desc.h index 3664bb5..d2d10c9 100644 --- a/game/src/desc.h +++ b/game/src/desc.h @@ -111,9 +111,6 @@ class DESC const struct sockaddr_in & GetAddr() { return m_SockAddr; } - void UDPGrant(const struct sockaddr_in & c_rSockAddr); - const struct sockaddr_in & GetUDPAddr() { return m_UDPSockAddr; } - void Log(const char * format, ...); // Çڵ彦ÀÌÅ© (½Ã°£ µ¿±âÈ­) @@ -222,7 +219,6 @@ class DESC TAccountTable m_accountTable; struct sockaddr_in m_SockAddr; - struct sockaddr_in m_UDPSockAddr; FILE * m_pLogFile; std::string m_stRelayName; diff --git a/game/src/desc_manager.cpp b/game/src/desc_manager.cpp index b70fb71..a141157 100644 --- a/game/src/desc_manager.cpp +++ b/game/src/desc_manager.cpp @@ -41,7 +41,7 @@ int IsValidIP(struct valid_ip* ip_table, const char *host) snprintf(ip_addr, sizeof(ip_addr), "%s.%d", (ip_table + i)->ip, (ip_table + i)->network + j); if (!strcmp(ip_addr, host)) - return TRUE; + return true; if (!j) break; @@ -49,7 +49,7 @@ int IsValidIP(struct valid_ip* ip_table, const char *host) while (j--); } - return FALSE; + return false; } DESC_MANAGER::DESC_MANAGER() : m_bDestroyed(false) diff --git a/game/src/event.cpp b/game/src/event.cpp index c8dc4d5..acf60ed 100644 --- a/game/src/event.cpp +++ b/game/src/event.cpp @@ -38,8 +38,8 @@ LPEVENT event_create_ex(TEVENTFUNC func, event_info_data* info, long when) new_event->func = func; new_event->info = info; new_event->q_el = cxx_q.Enqueue(new_event, when, thecore_heart->pulse); - new_event->is_processing = FALSE; - new_event->is_force_to_end = FALSE; + new_event->is_processing = false; + new_event->is_force_to_end = false; return (new_event); } @@ -60,10 +60,10 @@ void event_cancel(LPEVENT * ppevent) if (event->is_processing) { - event->is_force_to_end = TRUE; + event->is_force_to_end = true; if (event->q_el) - event->q_el->bCancel = TRUE; + event->q_el->bCancel = true; *ppevent = NULL; return; @@ -82,7 +82,7 @@ void event_cancel(LPEVENT * ppevent) return; } - event->q_el->bCancel = TRUE; + event->q_el->bCancel = true; *ppevent = NULL; } @@ -92,7 +92,7 @@ void event_reset_time(LPEVENT event, long when) if (!event->is_processing) { if (event->q_el) - event->q_el->bCancel = TRUE; + event->q_el->bCancel = true; event->q_el = cxx_q.Enqueue(event, when, thecore_heart->pulse); } @@ -127,7 +127,7 @@ int event_process(int pulse) * ¸®ÅÏ °ªÀ» 0 ÀÌ»óÀ¸·Î ÇÒ °æ¿ì event ¿¡ ÇÒ´çµÈ ¸Þ¸ð¸® Á¤º¸¸¦ »èÁ¦ÇÏÁö ¾Êµµ·Ï * ÁÖÀÇÇÑ´Ù. */ - the_event->is_processing = TRUE; + the_event->is_processing = true; if (!the_event->info) { @@ -146,7 +146,7 @@ int event_process(int pulse) else { the_event->q_el = cxx_q.Enqueue(the_event, new_time, pulse); - the_event->is_processing = FALSE; + the_event->is_processing = false; } } diff --git a/game/src/event_queue.cpp b/game/src/event_queue.cpp index 8c6d848..e0f88eb 100644 --- a/game/src/event_queue.cpp +++ b/game/src/event_queue.cpp @@ -39,7 +39,7 @@ TQueueElement * CEventQueue::Enqueue(LPEVENT pvData, int duration, int pulse) pElem->pvData = pvData; pElem->iStartTime = pulse; pElem->iKey = duration + pulse; - pElem->bCancel = FALSE; + pElem->bCancel = false; m_pq_queue.push(pElem); return pElem; diff --git a/game/src/group_text_parse_tree.h b/game/src/group_text_parse_tree.h index 3bf49c0..f12413b 100644 --- a/game/src/group_text_parse_tree.h +++ b/game/src/group_text_parse_tree.h @@ -116,7 +116,7 @@ template bool CGroupNode::GetValue(size_t i, const std::string & c_rstrColKey, T& tValue) const { if (i > m_map_rows.size()) - return FALSE; + return false; TMapRow::const_iterator row_it = m_map_rows.begin(); std::advance(row_it, i); @@ -124,13 +124,13 @@ bool CGroupNode::GetValue(size_t i, const std::string & c_rstrColKey, T& tValue) itertype(m_map_columnNameToIndex) col_idx_it = m_map_columnNameToIndex.find(c_rstrColKey); if (m_map_columnNameToIndex.end() == col_idx_it) { - return FALSE; + return false; } int index = col_idx_it->second; if (row_it->second.GetSize() <= index) { - return FALSE; + return false; } return row_it->second.GetValue(index, tValue); @@ -142,18 +142,18 @@ bool CGroupNode::GetValue(const std::string & c_rstrRowKey, const std::string & TMapRow::const_iterator row_it = m_map_rows.find(c_rstrRowKey); if (m_map_rows.end() == row_it) { - return FALSE; + return false; } itertype(m_map_columnNameToIndex) col_idx_it = m_map_columnNameToIndex.find(c_rstrColKey); if (m_map_columnNameToIndex.end() == col_idx_it) { - return FALSE; + return false; } int index = col_idx_it->second; if (row_it->second.GetSize() <= index) { - return FALSE; + return false; } return row_it->second.GetValue(index, tValue); @@ -165,12 +165,12 @@ bool CGroupNode::GetValue(const std::string & c_rstrRowKey, int index, T& tValue TMapRow::const_iterator row_it = m_map_rows.find(c_rstrRowKey); if (m_map_rows.end() == row_it) { - return FALSE; + return false; } if (row_it->second.GetSize() <= index) { - return FALSE; + return false; } return row_it->second.GetValue(index, tValue); } diff --git a/game/src/input.h b/game/src/input.h index ab9f008..3d51d31 100644 --- a/game/src/input.h +++ b/game/src/input.h @@ -11,7 +11,6 @@ enum INPROC_MAIN, INPROC_DEAD, INPROC_DB, - INPROC_UDP, INPROC_P2P, INPROC_AUTH, INPROC_TEEN, @@ -297,27 +296,6 @@ protected: DWORD m_dwHandle; }; -class CInputUDP : public CInputProcessor -{ - public: - CInputUDP(); - virtual bool Process(LPDESC d, const void * c_pvOrig, int iBytes, int & r_iBytesProceed); - - virtual BYTE GetType() { return INPROC_UDP; } - void SetSockAddr(struct sockaddr_in & rSockAddr) { m_SockAddr = rSockAddr; }; - - protected: - virtual int Analyze(LPDESC d, BYTE bHeader, const char * c_pData); - - protected: - void Handshake(LPDESC lpDesc, const char * c_pData); - void StateChecker(const char * c_pData); - - protected: - struct sockaddr_in m_SockAddr; - CPacketInfoUDP m_packetInfoUDP; -}; - class CInputP2P : public CInputProcessor { public: diff --git a/game/src/input_udp.cpp b/game/src/input_udp.cpp deleted file mode 100644 index b3f2bb7..0000000 --- a/game/src/input_udp.cpp +++ /dev/null @@ -1,194 +0,0 @@ -#include "stdafx.h" -#include "constants.h" -#include "config.h" -#include "input.h" -#include "desc.h" -#include "desc_manager.h" -#include "item_manager.h" -#include "char_manager.h" -#include "protocol.h" - -extern socket_t udp_socket; - -#define HEADER_CG_STATE_CHECKER 1 - -#pragma pack(1) - -typedef unsigned long ServerStateChecker_Key; -typedef unsigned long ServerStateChecker_Index; -typedef unsigned char ServerStateChecker_State; - -struct ServerStateChecker_RequestPacket -{ - BYTE header; - ServerStateChecker_Key key; - ServerStateChecker_Index index; -}; - -struct ServerStateChecker_ResponsePacket -{ - BYTE header; - ServerStateChecker_Key key; - ServerStateChecker_Index index; - ServerStateChecker_State state; -}; - -#pragma pack() - -///--------------------------------------------------------- - -CPacketInfoUDP::CPacketInfoUDP() -{ - Set(1, sizeof(ServerStateChecker_RequestPacket), "ServerStateRequest", false); -} - -CPacketInfoUDP::~CPacketInfoUDP() -{ - Log("udp_packet_info.txt"); -} - - -CInputUDP::CInputUDP() -{ - memset( &m_SockAddr, 0, sizeof(m_SockAddr) ); - - BindPacketInfo(&m_packetInfoUDP); -} - -void CInputUDP::Handshake(LPDESC pDesc, const char * c_pData) -{ - TPacketCGHandshake * pInfo = (TPacketCGHandshake *) c_pData; - - if (pDesc->GetHandshake() == pInfo->dwHandshake) - { - sys_log(0, "UDP: Grant %s:%d", inet_ntoa(m_SockAddr.sin_addr), m_SockAddr.sin_port); - pDesc->UDPGrant(m_SockAddr); - return; - } - else - sys_log(0, "UDP: Handshake differs %s", pDesc->GetHostName()); -} - -void CInputUDP::StateChecker(const char * c_pData) -{ - // NOTE : TCP ¿¬°á·Î ¹Ù²Ù¸é¼­ »ç¿ë X - /* - struct ServerStateChecker_RequestPacket * p = (struct ServerStateChecker_RequestPacket *) c_pData; - ServerStateChecker_ResponsePacket rp; - - int iTotal; - int * paiEmpireUserCount; - int iLocal; - - DESC_MANAGER::instance().GetUserCount(iTotal, &paiEmpireUserCount, iLocal); - - rp.header = 1; - rp.key = p->key; - rp.index = p->index; - - if (g_bNoMoreClient) - rp.state = 0; - else - rp.state = iTotal > g_iFullUserCount ? 3 : iTotal > g_iBusyUserCount ? 2 : 1; - - if (sendto(udp_socket, (const char*)&rp, sizeof(rp), 0, (const struct sockaddr *) &m_SockAddr, sizeof(m_SockAddr)) < 0) - { - sys_err("cannot sendto datagram socket : %s, %d", inet_ntoa(m_SockAddr.sin_addr), inet_ntoa(m_SockAddr.sin_addr)); - return; - } - */ -} - -int CInputUDP::Analyze(LPDESC pDesc, BYTE bHeader, const char * c_pData) -{ - switch (bHeader) - { - /* - case HEADER_CG_HANDSHAKE: - Handshake(pDesc, c_pData); - break; - - case HEADER_CG_STATE_CHECKER: - StateChecker(c_pData); - break; - */ - - default: - sys_err("unknown UDP header %u", bHeader); - break; - } - - return 0; -} - -bool CInputUDP::Process(LPDESC pDesc, const void * c_pvOrig, int iBytes, int & r_iBytesProceed) -{ - /* - const char * c_pData = static_cast (c_pvOrig); - - BYTE bLastHeader = 0; - int iLastPacketLen = 0; - int iPacketLen; - - if (!m_pPacketInfo) - { - sys_err("No packet info has been binded to"); - return true; - } - - for (m_iBufferLeft = iBytes; m_iBufferLeft > 0;) - { - if (m_iBufferLeft < 5) - return true; - - BYTE bHeader = (BYTE) *(c_pData); - const char * c_pszName; - - if (!m_pPacketInfo->Get(bHeader, &iPacketLen, &c_pszName)) - { - sys_err("UNKNOWN HEADER: %d, LAST HEADER: %d(%d), REMAIN BYTES: %d", - bHeader, bLastHeader, iLastPacketLen, m_iBufferLeft); - //printdata((BYTE *) c_pvOrig, iBytes); - return true; - } - - //DWORD dwHandshake = *(DWORD *) (c_pData + 1); - //pDesc = DESC_MANAGER::instance().FindByHandshake(dwHandshake); - - //if (!pDesc) - //{ - //sys_err("No desc by handshake %u", dwHandshake); - //return true; - //} - - //if (m_SockAddr.sin_addr.s_addr != pDesc->GetAddr().sin_addr.s_addr) - //{ - //sys_err("Hostname Mismatch! %s != %s", inet_ntoa(m_SockAddr.sin_addr), pDesc->GetHostName()); - //return true; - //} - - if (m_iBufferLeft < iPacketLen) - return true; - - int iExtraPacketSize = Analyze(pDesc, bHeader, c_pData); - - if (iExtraPacketSize < 0) - return true; - - iPacketLen += iExtraPacketSize; - - c_pData += iPacketLen; - m_iBufferLeft -= iPacketLen; - r_iBytesProceed += iPacketLen; - - iLastPacketLen = iPacketLen; - bLastHeader = bHeader; - - //if (GetType() != pDesc->GetInputProcessor()->GetType()) - //return false; - } - - */ - return true; -} - diff --git a/game/src/locale_service.cpp b/game/src/locale_service.cpp index 1682465..6c64d6f 100644 --- a/game/src/locale_service.cpp +++ b/game/src/locale_service.cpp @@ -418,7 +418,7 @@ static void __LocaleService_Init_JAPAN() g_setQuestObjectDir.insert("locale/japan/quest/object"); g_stLocaleFilename = "locale/japan/sjis_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_sjis; is_twobyte = is_twobyte_sjis; @@ -436,7 +436,7 @@ static void __LocaleService_Init_English() g_setQuestObjectDir.insert("locale/english/quest/object"); g_stLocaleFilename = "locale/english/eng_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; } @@ -451,7 +451,7 @@ static void __LocaleService_Init_HongKong() g_setQuestObjectDir.insert("locale/hongkong/quest/object"); g_stLocaleFilename = "locale/hongkong/big5_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_big5; is_twobyte = is_twobyte_big5; @@ -468,7 +468,7 @@ static void __LocaleService_Init_NewCIBN() g_setQuestObjectDir.insert("locale/newcibn/quest/object"); g_stLocaleFilename = "locale/newcibn/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_gb2312; is_twobyte = is_twobyte_gb2312; @@ -486,7 +486,7 @@ static void __LocaleService_Init_Germany() g_setQuestObjectDir.insert("locale/germany/quest/object"); g_stLocaleFilename = "locale/germany/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -503,7 +503,7 @@ static void __LocaleService_Init_Korea() g_setQuestObjectDir.clear(); g_setQuestObjectDir.insert("locale/korea/quest/object"); - g_iUseLocale = TRUE; + g_iUseLocale = true; exp_table = exp_table_euckr; } @@ -518,7 +518,7 @@ static void __LocaleService_Init_France() g_setQuestObjectDir.insert("locale/france/quest/object"); g_stLocaleFilename = "locale/france/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -536,7 +536,7 @@ static void __LocaleService_Init_Italy() g_setQuestObjectDir.insert("locale/italy/quest/object"); g_stLocaleFilename = "locale/italy/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -554,7 +554,7 @@ static void __LocaleService_Init_spain() g_setQuestObjectDir.insert("locale/spain/quest/object"); g_stLocaleFilename = "locale/spain/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -572,7 +572,7 @@ static void __LocaleService_Init_greek() g_setQuestObjectDir.insert("locale/greek/quest/object"); g_stLocaleFilename = "locale/greek/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -590,7 +590,7 @@ static void __LocaleService_Init_UK() g_setQuestObjectDir.insert("locale/uk/quest/object"); g_stLocaleFilename = "locale/uk/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -608,7 +608,7 @@ static void __LocaleService_Init_Turkey() g_setQuestObjectDir.insert("locale/turkey/quest/object"); g_stLocaleFilename = "locale/turkey/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -626,7 +626,7 @@ static void __LocaleService_Init_Poland() g_setQuestObjectDir.insert("locale/poland/quest/object"); g_stLocaleFilename = "locale/poland/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -644,7 +644,7 @@ static void __LocaleService_Init_Portugal() g_setQuestObjectDir.insert("locale/portugal/quest/object"); g_stLocaleFilename = "locale/portugal/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -664,7 +664,7 @@ static void __LocaleService_Init_Canada() check_name = check_name_alphabet; - g_iUseLocale = TRUE; + g_iUseLocale = true; } static void __LocaleService_Init_Brazil() @@ -680,7 +680,7 @@ static void __LocaleService_Init_Brazil() check_name = check_name_alphabet; - g_iUseLocale = TRUE; + g_iUseLocale = true; } static void __LocaleService_Init_YMIR() @@ -710,7 +710,7 @@ static void __LocaleService_Init_Russia() g_setQuestObjectDir.insert("locale/russia/quest/object"); g_stLocaleFilename = "locale/russia/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -728,7 +728,7 @@ static void __LocaleService_Init_Denmark() g_setQuestObjectDir.insert("locale/denmark/quest/object"); g_stLocaleFilename = "locale/denmark/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -746,7 +746,7 @@ static void __LocaleService_Init_Bulgaria() g_setQuestObjectDir.insert("locale/bulgaria/quest/object"); g_stLocaleFilename = "locale/bulgaria/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -764,7 +764,7 @@ static void __LocaleService_Init_Croatia() g_setQuestObjectDir.insert("locale/croatia/quest/object"); g_stLocaleFilename = "locale/croatia/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -782,7 +782,7 @@ static void __LocaleService_Init_Mexico() g_setQuestObjectDir.insert("locale/mexico/quest/object"); g_stLocaleFilename = "locale/mexico/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -800,7 +800,7 @@ static void __LocaleService_Init_Arabia() g_setQuestObjectDir.insert("locale/arabia/quest/object"); g_stLocaleFilename = "locale/arabia/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -818,7 +818,7 @@ static void __LocaleService_Init_Czech() g_setQuestObjectDir.insert("locale/czech/quest/object"); g_stLocaleFilename = "locale/czech/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -836,7 +836,7 @@ static void __LocaleService_Init_Hungary() g_setQuestObjectDir.insert("locale/hungary/quest/object"); g_stLocaleFilename = "locale/hungary/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -854,7 +854,7 @@ static void __LocaleService_Init_Romania() g_setQuestObjectDir.insert("locale/romania/quest/object"); g_stLocaleFilename = "locale/romania/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -872,7 +872,7 @@ static void __LocaleService_Init_Netherlands() g_setQuestObjectDir.insert("locale/netherlands/quest/object"); g_stLocaleFilename = "locale/netherlands/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; @@ -892,7 +892,7 @@ static void __LocaleService_Init_Singapore() check_name = check_name_alphabet; - g_iUseLocale = TRUE; + g_iUseLocale = true; //exp_table = exp_table_newcibn; 2013 09 11 CYH europe °ú µ¿ÀÏÇÏ°Ô °£´Ù. } @@ -909,7 +909,7 @@ static void __LocaleService_Init_Vietnam() check_name = check_name_alphabet; - g_iUseLocale = TRUE; + g_iUseLocale = true; exp_table = exp_table_newcibn; } @@ -927,7 +927,7 @@ static void __LocaleService_Init_Thailand() check_name = check_name_alphabet; - g_iUseLocale = TRUE; + g_iUseLocale = true; } static void __LocaleService_Init_USA() @@ -941,7 +941,7 @@ static void __LocaleService_Init_USA() g_setQuestObjectDir.insert("locale/usa/quest/object"); g_stLocaleFilename = "locale/usa/locale_string.txt"; - g_iUseLocale = TRUE; + g_iUseLocale = true; check_name = check_name_alphabet; } @@ -959,7 +959,7 @@ static void __LocaleService_Init_WE_Korea() g_setQuestObjectDir.clear(); g_setQuestObjectDir.insert(g_stQuestDir + "/object"); - g_iUseLocale = TRUE; + g_iUseLocale = true; PK_PROTECT_LEVEL = 15; } @@ -978,7 +978,7 @@ static void __LocaleService_Init_Taiwan() check_name = check_name_big5; is_twobyte = is_twobyte_big5; - g_iUseLocale = TRUE; + g_iUseLocale = true; PK_PROTECT_LEVEL = 15; } diff --git a/game/src/main.cpp b/game/src/main.cpp index 259d56c..718db39 100644 --- a/game/src/main.cpp +++ b/game/src/main.cpp @@ -96,7 +96,6 @@ int total_bytes_written = 0; BYTE g_bLogLevel = 0; socket_t tcp_socket = 0; -socket_t udp_socket = 0; socket_t p2p_socket = 0; LPFDWATCH main_fdw = NULL; @@ -617,15 +616,6 @@ int start(int argc, char **argv) return 0; } - -#ifndef __UDP_BLOCK__ - if ((udp_socket = socket_udp_bind(g_szPublicIP, mother_port)) == INVALID_SOCKET) - { - perror("socket_udp_bind: udp_socket"); - return 0; - } -#endif - // if internal ip exists, p2p socket uses internal ip, if not use public ip //if ((p2p_socket = socket_tcp_bind(*g_szInternalIP ? g_szInternalIP : g_szPublicIP, p2p_port)) == INVALID_SOCKET) if ((p2p_socket = socket_tcp_bind(g_szPublicIP, p2p_port)) == INVALID_SOCKET) @@ -635,9 +625,6 @@ int start(int argc, char **argv) } fdwatch_add_fd(main_fdw, tcp_socket, NULL, FDW_READ, false); -#ifndef __UDP_BLOCK__ - fdwatch_add_fd(main_fdw, udp_socket, NULL, FDW_READ, false); -#endif fdwatch_add_fd(main_fdw, p2p_socket, NULL, FDW_READ, false); db_clientdesc = DESC_MANAGER::instance().CreateConnectionDesc(main_fdw, db_addr, db_port, PHASE_DBCLIENT, true); @@ -691,9 +678,6 @@ void destroy() sys_log(0, " Closing sockets..."); socket_close(tcp_socket); -#ifndef __UDP_BLOCK__ - socket_close(udp_socket); -#endif socket_close(p2p_socket); sys_log(0, " fdwatch_delete()..."); @@ -815,28 +799,6 @@ int io_loop(LPFDWATCH fdw) DESC_MANAGER::instance().AcceptP2PDesc(fdw, p2p_socket); fdwatch_clear_event(fdw, p2p_socket, event_idx); } - /* - else if (FDW_READ == fdwatch_check_event(fdw, udp_socket, event_idx)) - { - char buf[256]; - struct sockaddr_in cliaddr; - socklen_t socklen = sizeof(cliaddr); - - int iBytesRead; - - if ((iBytesRead = socket_udp_read(udp_socket, buf, 256, (struct sockaddr *) &cliaddr, &socklen)) > 0) - { - static CInputUDP s_inputUDP; - - s_inputUDP.SetSockAddr(cliaddr); - - int iBytesProceed; - s_inputUDP.Process(NULL, buf, iBytesRead, iBytesProceed); - } - - fdwatch_clear_event(fdw, udp_socket, event_idx); - } - */ continue; } diff --git a/game/src/packet.h b/game/src/packet.h index 5704219..ab0e230 100644 --- a/game/src/packet.h +++ b/game/src/packet.h @@ -113,7 +113,6 @@ enum HEADER_GC_KEY_AGREEMENT = 0xfb, // _IMPROVED_PACKET_ENCRYPTION_ HEADER_GC_TIME_SYNC = 0xfc, HEADER_GC_PHASE = 0xfd, - HEADER_GC_BINDUDP = 0xfe, HEADER_GC_HANDSHAKE = 0xff, HEADER_GC_CHARACTER_ADD = 1, @@ -854,13 +853,6 @@ typedef struct packet_phase BYTE phase; } TPacketGCPhase; -typedef struct packet_bindudp -{ - BYTE header; - DWORD addr; - WORD port; -} TPacketGCBindUDP; - enum { LOGIN_FAILURE_ALREADY = 1, diff --git a/game/src/packet_info.h b/game/src/packet_info.h index 8f2cebe..70c64b0 100644 --- a/game/src/packet_info.h +++ b/game/src/packet_info.h @@ -53,12 +53,4 @@ class CPacketInfoGG : public CPacketInfo virtual ~CPacketInfoGG(); }; -/// Implemented in input_udp.cpp -class CPacketInfoUDP : public CPacketInfo -{ - public: - CPacketInfoUDP(); - virtual ~CPacketInfoUDP(); -}; - #endif diff --git a/game/src/questlua_npc.cpp b/game/src/questlua_npc.cpp index ffee1ca..455fb8c 100644 --- a/game/src/questlua_npc.cpp +++ b/game/src/questlua_npc.cpp @@ -243,18 +243,18 @@ namespace quest if (!npc || npc->IsPC()) { - lua_pushboolean(L, TRUE); + lua_pushboolean(L, true); return 1; } if (npc->GetQuestNPCID() == 0 || npc->GetQuestNPCID() == ch->GetPlayerID()) { npc->SetQuestNPCID(ch->GetPlayerID()); - lua_pushboolean(L, TRUE); + lua_pushboolean(L, true); } else { - lua_pushboolean(L, FALSE); + lua_pushboolean(L, true); } return 1; diff --git a/game/src/text_file_loader.cpp b/game/src/text_file_loader.cpp index 594cb65..8ff2397 100644 --- a/game/src/text_file_loader.cpp +++ b/game/src/text_file_loader.cpp @@ -168,7 +168,7 @@ BOOL CTextFileLoader::SetChildNode(const char * c_szKey) if (!m_pcurNode) { assert(!"Node to access has not set!"); - return FALSE; + return false; } for (DWORD i = 0; i < m_pcurNode->ChildNodeVector.size(); ++i) @@ -177,11 +177,11 @@ BOOL CTextFileLoader::SetChildNode(const char * c_szKey) if (0 == pGroupNode->strGroupName.compare(c_szKey)) { m_pcurNode = pGroupNode; - return TRUE; + return true; } } - return FALSE; + return false; } BOOL CTextFileLoader::SetChildNode(const std::string & c_rstrKeyHead, DWORD dwIndex) @@ -196,18 +196,18 @@ BOOL CTextFileLoader::SetChildNode(DWORD dwIndex) if (!m_pcurNode) { assert(!"Node to access has not set!"); - return FALSE; + return false; } if (dwIndex >= m_pcurNode->ChildNodeVector.size()) { assert(!"Node index to set is too large to access!"); - return FALSE; + return false; } m_pcurNode = m_pcurNode->ChildNodeVector[dwIndex]; - return TRUE; + return true; } BOOL CTextFileLoader::SetParentNode() @@ -215,30 +215,30 @@ BOOL CTextFileLoader::SetParentNode() if (!m_pcurNode) { assert(!"Node to access has not set!"); - return FALSE; + return false; } if (NULL == m_pcurNode->pParentNode) { assert(!"Current group node is already top!"); - return FALSE; + return false; } m_pcurNode = m_pcurNode->pParentNode; - return TRUE; + return true; } BOOL CTextFileLoader::GetCurrentNodeName(std::string * pstrName) { if (!m_pcurNode) - return FALSE; + return false; if (NULL == m_pcurNode->pParentNode) - return FALSE; + return false; *pstrName = m_pcurNode->strGroupName; - return TRUE; + return true; } BOOL CTextFileLoader::IsToken(const std::string & c_rstrKey) @@ -246,7 +246,7 @@ BOOL CTextFileLoader::IsToken(const std::string & c_rstrKey) if (!m_pcurNode) { assert(!"Node to access has not set!"); - return FALSE; + return false; } return m_pcurNode->LocalTokenVectorMap.end() != m_pcurNode->LocalTokenVectorMap.find(c_rstrKey); @@ -257,95 +257,95 @@ BOOL CTextFileLoader::GetTokenVector(const std::string & c_rstrKey, TTokenVector if (!m_pcurNode) { assert(!"Node to access has not set!"); - return FALSE; + return false; } TTokenVectorMap::iterator it = m_pcurNode->LocalTokenVectorMap.find(c_rstrKey); if (m_pcurNode->LocalTokenVectorMap.end() == it) { sys_log(2, " CTextFileLoader::GetTokenVector - Failed to find the key %s [%s :: %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } *ppTokenVector = &it->second; - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenBoolean(const std::string & c_rstrKey, BOOL * pData) { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->empty()) { sys_log(2, " CTextFileLoader::GetTokenBoolean - Failed to find the value %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } BOOL out = 0; str_to_number(out, pTokenVector->at(0).c_str()); *pData = out; - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenByte(const std::string & c_rstrKey, BYTE * pData) { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->empty()) { sys_log(2, " CTextFileLoader::GetTokenByte - Failed to find the value %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } BYTE out = 0; str_to_number(out, pTokenVector->at(0).c_str()); *pData = out; - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenWord(const std::string & c_rstrKey, WORD * pData) { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->empty()) { sys_log(2, " CTextFileLoader::GetTokenWord - Failed to find the value %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } WORD out = 0; str_to_number(out, pTokenVector->at(0).c_str()); *pData = out; - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenInteger(const std::string & c_rstrKey, int * pData) { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->empty()) { sys_log(2, " CTextFileLoader::GetTokenInteger - Failed to find the value %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } int out = 0; str_to_number(out, pTokenVector->at(0).c_str()); *pData = out; - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenDoubleWord(const std::string & c_rstrKey, DWORD * pData) @@ -357,66 +357,66 @@ BOOL CTextFileLoader::GetTokenFloat(const std::string & c_rstrKey, float * pData { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->empty()) { sys_log(2, " CTextFileLoader::GetTokenFloat - Failed to find the value %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } *pData = atof(pTokenVector->at(0).c_str()); - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenVector2(const std::string & c_rstrKey, D3DXVECTOR2 * pVector2) { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->size() != 2) { sys_log(2, " CTextFileLoader::GetTokenVector2 - This key should have 2 values %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } pVector2->x = atof(pTokenVector->at(0).c_str()); pVector2->y = atof(pTokenVector->at(1).c_str()); - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenVector3(const std::string & c_rstrKey, D3DXVECTOR3 * pVector3) { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->size() != 3) { sys_log(2, " CTextFileLoader::GetTokenVector3 - This key should have 3 values %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } pVector3->x = atof(pTokenVector->at(0).c_str()); pVector3->y = atof(pTokenVector->at(1).c_str()); pVector3->z = atof(pTokenVector->at(2).c_str()); - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenVector4(const std::string & c_rstrKey, D3DXVECTOR4 * pVector4) { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->size() != 4) { sys_log(2, " CTextFileLoader::GetTokenVector3 - This key should have 3 values %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } pVector4->x = atof(pTokenVector->at(0).c_str()); @@ -424,7 +424,7 @@ BOOL CTextFileLoader::GetTokenVector4(const std::string & c_rstrKey, D3DXVECTOR4 pVector4->z = atof(pTokenVector->at(2).c_str()); pVector4->w = atof(pTokenVector->at(3).c_str()); - return TRUE; + return true; } @@ -437,49 +437,49 @@ BOOL CTextFileLoader::GetTokenQuaternion(const std::string & c_rstrKey, D3DXQUAT { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->size() != 4) { sys_log(2, " CTextFileLoader::GetTokenVector3 - This key should have 3 values %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } pQ->x = atof(pTokenVector->at(0).c_str()); pQ->y = atof(pTokenVector->at(1).c_str()); pQ->z = atof(pTokenVector->at(2).c_str()); pQ->w = atof(pTokenVector->at(3).c_str()); - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenDirection(const std::string & c_rstrKey, D3DVECTOR * pVector) { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->size() != 3) { sys_log(2, " CTextFileLoader::GetTokenDirection - This key should have 3 values %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } pVector->x = atof(pTokenVector->at(0).c_str()); pVector->y = atof(pTokenVector->at(1).c_str()); pVector->z = atof(pTokenVector->at(2).c_str()); - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenColor(const std::string & c_rstrKey, D3DXCOLOR * pColor) { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->size() != 4) { sys_log(2, " CTextFileLoader::GetTokenColor - This key should have 4 values %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } pColor->r = atof(pTokenVector->at(0).c_str()); @@ -487,19 +487,19 @@ BOOL CTextFileLoader::GetTokenColor(const std::string & c_rstrKey, D3DXCOLOR * p pColor->b = atof(pTokenVector->at(2).c_str()); pColor->a = atof(pTokenVector->at(3).c_str()); - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenColor(const std::string & c_rstrKey, D3DCOLORVALUE * pColor) { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->size() != 4) { sys_log(2, " CTextFileLoader::GetTokenColor - This key should have 4 values %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } pColor->r = atof(pTokenVector->at(0).c_str()); @@ -507,23 +507,23 @@ BOOL CTextFileLoader::GetTokenColor(const std::string & c_rstrKey, D3DCOLORVALUE pColor->b = atof(pTokenVector->at(2).c_str()); pColor->a = atof(pTokenVector->at(3).c_str()); - return TRUE; + return true; } BOOL CTextFileLoader::GetTokenString(const std::string & c_rstrKey, std::string * pString) { TTokenVector * pTokenVector; if (!GetTokenVector(c_rstrKey, &pTokenVector)) - return FALSE; + return false; if (pTokenVector->empty()) { sys_log(2, " CTextFileLoader::GetTokenString - Failed to find the value %s [%s : %s]", m_strFileName.c_str(), m_pcurNode->strGroupName.c_str(), c_rstrKey.c_str()); - return FALSE; + return false; } *pString = pTokenVector->at(0); - return TRUE; + return true; } diff --git a/game/src/utils.cpp b/game/src/utils.cpp index 14adf0e..7473a17 100644 --- a/game/src/utils.cpp +++ b/game/src/utils.cpp @@ -70,7 +70,7 @@ void skip_spaces(const char **string) const char *one_argument(const char *argument, char *first_arg, size_t first_size) { - char mark = FALSE; + bool mark = false; size_t first_len = 0; if (!argument || 0 == first_size) diff --git a/libsql/CMakeLists.txt b/libsql/CMakeLists.txt index 06c13d3..cb8a63c 100644 --- a/libsql/CMakeLists.txt +++ b/libsql/CMakeLists.txt @@ -16,14 +16,8 @@ add_library(${PROJECT_NAME} STATIC ${SOURCES}) # Find dependencies find_package(libmysql REQUIRED) +target_link_libraries(${PROJECT_NAME} PRIVATE ${MYSQL_LIBRARIES}) + find_package(Boost REQUIRED) - -# Link dependencies if found -if (libmysql_FOUND) - target_link_libraries (${PROJECT_NAME} ${MYSQL_LIBRARIES}) -endif (libmysql_FOUND) - -if (Boost_FOUND) - include_directories(${Boost_INCLUDE_DIRS}) - target_link_libraries (${PROJECT_NAME} ${Boost_LIBRARIES}) -endif (Boost_FOUND) \ No newline at end of file +include_directories(${Boost_INCLUDE_DIRS}) +target_link_libraries(${PROJECT_NAME} PRIVATE ${Boost_LIBRARIES}) diff --git a/libthecore/CMakeLists.txt b/libthecore/CMakeLists.txt index 4e6d6dc..7ac98e8 100644 --- a/libthecore/CMakeLists.txt +++ b/libthecore/CMakeLists.txt @@ -16,9 +16,5 @@ add_library(${PROJECT_NAME} STATIC ${SOURCES}) # Find dependencies find_package(Boost REQUIRED) - -# Link dependencies if found -if (Boost_FOUND) - include_directories(${Boost_INCLUDE_DIRS}) - target_link_libraries (${PROJECT_NAME} ${Boost_LIBRARIES}) -endif (Boost_FOUND) \ No newline at end of file +include_directories(${Boost_INCLUDE_DIRS}) +target_link_libraries(${PROJECT_NAME} PRIVATE ${Boost_LIBRARIES}) diff --git a/libthecore/include/fdwatch.h b/libthecore/include/fdwatch.h deleted file mode 100644 index 2c09c3e..0000000 --- a/libthecore/include/fdwatch.h +++ /dev/null @@ -1,95 +0,0 @@ -#ifndef __INC_LIBTHECORE_FDWATCH_H__ -#define __INC_LIBTHECORE_FDWATCH_H__ - -#if defined(WIN32) || defined(__linux__) - - typedef struct fdwatch FDWATCH; - typedef struct fdwatch * LPFDWATCH; - - enum EFdwatch - { - FDW_NONE = 0, - FDW_READ = 1, - FDW_WRITE = 2, - FDW_WRITE_ONESHOT = 4, - FDW_EOF = 8, - }; - - struct fdwatch - { - fd_set rfd_set; - fd_set wfd_set; - - socket_t* select_fds; - int* select_rfdidx; - - int nselect_fds; - - fd_set working_rfd_set; - fd_set working_wfd_set; - - int nfiles; - - void** fd_data; - int* fd_rw; - }; - -#else - -typedef struct fdwatch FDWATCH; -typedef struct fdwatch* LPFDWATCH; - -enum EFdwatch -{ - FDW_NONE = 0, - FDW_READ = 1, - FDW_WRITE = 2, - FDW_WRITE_ONESHOT = 4, - FDW_EOF = 8, -}; - -typedef struct kevent KEVENT; -typedef struct kevent* LPKEVENT; -typedef int KQUEUE; - -struct fdwatch -{ - KQUEUE kq; - - int nfiles; - - LPKEVENT kqevents; - int nkqevents; - - LPKEVENT kqrevents; - int* fd_event_idx; - - void** fd_data; - int* fd_rw; -}; - -#endif // WIN32 - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - - extern LPFDWATCH fdwatch_new(int nfiles); - extern void fdwatch_clear_fd(LPFDWATCH fdw, socket_t fd); - extern void fdwatch_delete(LPFDWATCH fdw); - extern int fdwatch_check_fd(LPFDWATCH fdw, socket_t fd); - extern int fdwatch_check_event(LPFDWATCH fdw, socket_t fd, unsigned int event_idx); - extern void fdwatch_clear_event(LPFDWATCH fdw, socket_t fd, unsigned int event_idx); - extern void fdwatch_add_fd(LPFDWATCH fdw, socket_t fd, void* client_data, int rw, int oneshot); - extern int fdwatch(LPFDWATCH fdw, struct timeval *timeout); - extern void * fdwatch_get_client_data(LPFDWATCH fdw, unsigned int event_idx); - extern void fdwatch_del_fd(LPFDWATCH fdw, socket_t fd); - extern int fdwatch_get_buffer_size(LPFDWATCH fdw, socket_t fd); - extern int fdwatch_get_ident(LPFDWATCH fdw, unsigned int event_idx); - -#ifdef __cplusplus -} -#endif - -#endif diff --git a/libthecore/include/signal.h b/libthecore/include/signals.h similarity index 100% rename from libthecore/include/signal.h rename to libthecore/include/signals.h diff --git a/libthecore/include/socket.h b/libthecore/include/socket.h deleted file mode 100644 index 4ef63ce..0000000 --- a/libthecore/include/socket.h +++ /dev/null @@ -1,45 +0,0 @@ -/* - * Filename: socket.c - * Description: ¼ÒÄÏ °ü·Ã ÇÔ¼ö Çì´õ. - * - * Author: ºñ¿± (server), myevan (Client) - */ -#ifndef __INC_LIBTHECORE_SOCKET_H__ -#define __INC_LIBTHECORE_SOCKET_H__ - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - -#ifdef __WIN32__ -typedef int socklen_t; -#else -#define INVALID_SOCKET -1 -#endif - - extern int socket_read(socket_t desc, char* read_point, size_t space_left); - extern int socket_write(socket_t desc, const char *data, size_t length); - - extern int socket_udp_read(socket_t desc, char * read_point, size_t space_left, struct sockaddr * from, socklen_t * fromlen); - extern int socket_tcp_bind(const char * ip, int port); - extern int socket_udp_bind(const char * ip, int port); - - extern socket_t socket_accept(socket_t s, struct sockaddr_in *peer); - extern void socket_close(socket_t s); - extern socket_t socket_connect(const char* host, WORD port); - - extern void socket_nonblock(socket_t s); - extern void socket_block(socket_t s); - extern void socket_dontroute(socket_t s); - extern void socket_lingeroff(socket_t s); - extern void socket_lingeron(socket_t s); - - extern void socket_sndbuf(socket_t s, unsigned int opt); - extern void socket_rcvbuf(socket_t s, unsigned int opt); - -#ifdef __cplusplus -}; -#endif - -#endif diff --git a/libthecore/include/stdafx.h b/libthecore/include/stdafx.h index 8485c67..52608a1 100644 --- a/libthecore/include/stdafx.h +++ b/libthecore/include/stdafx.h @@ -1,100 +1,16 @@ #ifndef __INC_LIBTHECORE_STDAFX_H__ #define __INC_LIBTHECORE_STDAFX_H__ -#if defined(__GNUC__) -#define INLINE __inline__ -#elif defined(_MSC_VER) -#define INLINE inline -#endif - -#ifdef __WIN32__ -#define WIN32_LEAN_AND_MEAN - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include "xdirent.h" -#include "xgetopt.h" - -#define S_ISDIR(m) (m & _S_IFDIR) -#define snprintf _snprintf - -struct timespec -{ - time_t tv_sec; /* seconds */ - long tv_nsec; /* and nanoseconds */ -}; - -#define __USE_SELECT__ - -#define PATH_MAX _MAX_PATH - -// C runtime library adjustments -#define strncat(dst, src, size) strcat_s(dst, size, src) -#define strncpy(dst, src, size) strncpy_s(dst, size, src, _TRUNCATE) -#define strtoull(str, endptr, base) _strtoui64(str, endptr, base) -#define strtof(str, endptr) (float)strtod(str, endptr) -#define strcasecmp(s1, s2) stricmp(s1, s2) -#define strncasecmp(s1, s2, n) strnicmp(s1, s2, n) -#define atoll(str) _atoi64(str) -#define localtime_r(timet, result) localtime_s(result, timet) -#define strtok_r(s, delim, ptrptr) strtok_s(s, delim, ptrptr) - -#include -#define typeof(t) BOOST_TYPEOF(t) - -// dummy declaration of non-supported signals -#define SIGUSR1 30 /* user defined signal 1 */ -#define SIGUSR2 31 /* user defined signal 2 */ - -inline void usleep(unsigned long usec) { - ::Sleep(usec / 1000); -} -inline unsigned sleep(unsigned sec) { - ::Sleep(sec * 1000); - return 0; -} -inline double rint(double x) -{ - return ::floor(x+.5); -} - - -#else - -#ifndef __FreeBSD__ -#define __USE_SELECT__ -#ifdef __CYGWIN__ -#define _POSIX_SOURCE 1 -#endif -#endif - -#include -#include -#include -#include -#include +#include +#include +#include +#include +#include #include #include -#include -#include -#include +#include +#include +#include #include #include @@ -112,28 +28,10 @@ inline double rint(double x) #include #include -#ifdef __FreeBSD__ -#include -#endif - -#endif - -#ifndef false -#define false 0 -#define true (!false) -#endif - -#ifndef FALSE -#define FALSE false -#define TRUE (!FALSE) -#endif - #include "typedef.h" #include "heart.h" -#include "fdwatch.h" -#include "socket.h" #include "buffer.h" -#include "signal.h" +#include "signals.h" #include "log.h" #include "main.h" #include "utils.h" diff --git a/libthecore/include/typedef.h b/libthecore/include/typedef.h index 1bf9b48..4c981e2 100644 --- a/libthecore/include/typedef.h +++ b/libthecore/include/typedef.h @@ -1,27 +1,23 @@ #ifndef __INC_LIBTHECORE_TYPEDEF_H__ #define __INC_LIBTHECORE_TYPEDEF_H__ -typedef unsigned long int QWORD; -typedef unsigned char UBYTE; -typedef signed char sbyte; -typedef unsigned short sh_int; +#include + +typedef uint64_t QWORD; +typedef uint8_t UBYTE; +typedef int8_t sbyte; +typedef uint16_t sh_int; #ifndef __WIN32__ -#ifndef __cplusplus -typedef unsigned char bool; -#endif - -typedef unsigned int DWORD; -typedef int BOOL; -typedef unsigned char BYTE; -typedef unsigned short WORD; -typedef long LONG; -typedef unsigned long ULONG; -typedef int INT; -typedef unsigned int UINT; - -typedef int socket_t; +typedef uint32_t DWORD; +typedef uint32_t BOOL; +typedef uint8_t BYTE; +typedef uint16_t WORD; +typedef int32_t LONG; +typedef uint32_t ULONG; +typedef int32_t INT; +typedef uint32_t UINT; #else diff --git a/libthecore/src/fdwatch.cpp b/libthecore/src/fdwatch.cpp deleted file mode 100644 index 3ae848c..0000000 --- a/libthecore/src/fdwatch.cpp +++ /dev/null @@ -1,461 +0,0 @@ -#define __LIBTHECORE__ -#include "stdafx.h" - -#ifndef __USE_SELECT__ - -LPFDWATCH fdwatch_new(int nfiles) -{ - LPFDWATCH fdw; - int kq; - - kq = kqueue(); - - if (kq == -1) - { - sys_err("%s", strerror(errno)); - return NULL; - } - - CREATE(fdw, FDWATCH, 1); - - fdw->kq = kq; - fdw->nfiles = nfiles; - fdw->nkqevents = 0; - - CREATE(fdw->kqevents, KEVENT, nfiles * 2); - CREATE(fdw->kqrevents, KEVENT, nfiles * 2); - CREATE(fdw->fd_event_idx, int, nfiles); - CREATE(fdw->fd_rw, int, nfiles); - CREATE(fdw->fd_data, void*, nfiles); - - return (fdw); -} - -void fdwatch_delete(LPFDWATCH fdw) -{ - free(fdw->fd_data); - free(fdw->fd_rw); - free(fdw->kqevents); - free(fdw->kqrevents); - free(fdw->fd_event_idx); - free(fdw); -} - -int fdwatch(LPFDWATCH fdw, struct timeval *timeout) -{ - int i, r; - struct timespec ts; - - if (fdw->nkqevents) - sys_log(2, "fdwatch: nkqevents %d", fdw->nkqevents); - - if (!timeout) - { - ts.tv_sec = 0; - ts.tv_nsec = 0; - - r = kevent(fdw->kq, fdw->kqevents, fdw->nkqevents, fdw->kqrevents, fdw->nfiles, &ts); - } - else - { - ts.tv_sec = timeout->tv_sec; - ts.tv_nsec = timeout->tv_usec; - - r = kevent(fdw->kq, fdw->kqevents, fdw->nkqevents, fdw->kqrevents, fdw->nfiles, &ts); - } - - fdw->nkqevents = 0; - - if (r == -1) - return -1; - - memset(fdw->fd_event_idx, 0, sizeof(int) * fdw->nfiles); - - for (i = 0; i < r; i++) - { - int fd = fdw->kqrevents[i].ident; - - if (fd >= fdw->nfiles) - sys_err("ident overflow %d nfiles: %d", fdw->kqrevents[i].ident, fdw->nfiles); - else - { - if (fdw->kqrevents[i].filter == EVFILT_WRITE) - fdw->fd_event_idx[fd] = i; - } - } - - return (r); -} - -void fdwatch_register(LPFDWATCH fdw, int flag, int fd, int rw) -{ - if (flag == EV_DELETE) - { - if (fdw->fd_rw[fd] & FDW_READ) - { - fdw->kqevents[fdw->nkqevents].ident = fd; - fdw->kqevents[fdw->nkqevents].flags = flag; - fdw->kqevents[fdw->nkqevents].filter = EVFILT_READ; - ++fdw->nkqevents; - } - - if (fdw->fd_rw[fd] & FDW_WRITE) - { - fdw->kqevents[fdw->nkqevents].ident = fd; - fdw->kqevents[fdw->nkqevents].flags = flag; - fdw->kqevents[fdw->nkqevents].filter = EVFILT_WRITE; - ++fdw->nkqevents; - } - } - else - { - fdw->kqevents[fdw->nkqevents].ident = fd; - fdw->kqevents[fdw->nkqevents].flags = flag; - fdw->kqevents[fdw->nkqevents].filter = (rw == FDW_READ) ? EVFILT_READ : EVFILT_WRITE; - - ++fdw->nkqevents; - } -} - -void fdwatch_clear_fd(LPFDWATCH fdw, socket_t fd) -{ - fdw->fd_data[fd] = NULL; - fdw->fd_rw[fd] = 0; -} - -void fdwatch_add_fd(LPFDWATCH fdw, socket_t fd, void * client_data, int rw, int oneshot) -{ - int flag; - - if (fd >= fdw->nfiles) - { - sys_err("fd overflow %d", fd); - return; - } - - if (fdw->fd_rw[fd] & rw) - return; - - fdw->fd_rw[fd] |= rw; - sys_log(2, "FDWATCH_REGISTER fdw %p fd %d rw %d data %p", fdw, fd, rw, client_data); - - if (!oneshot) - flag = EV_ADD; - else - { - sys_log(2, "ADD ONESHOT fd_rw %d", fdw->fd_rw[fd]); - flag = EV_ADD | EV_ONESHOT; - fdw->fd_rw[fd] |= FDW_WRITE_ONESHOT; - } - - fdw->fd_data[fd] = client_data; - fdwatch_register(fdw, flag, fd, rw); -} - -void fdwatch_del_fd(LPFDWATCH fdw, socket_t fd) -{ - fdwatch_register(fdw, EV_DELETE, fd, 0); - fdwatch_clear_fd(fdw, fd); -} - -void fdwatch_clear_event(LPFDWATCH fdw, socket_t fd, unsigned int event_idx) -{ - assert(event_idx < fdw->nfiles * 2); - - if (fdw->kqrevents[event_idx].ident != fd) - return; - - fdw->kqrevents[event_idx].ident = 0; -} - -int fdwatch_check_event(LPFDWATCH fdw, socket_t fd, unsigned int event_idx) -{ - assert(event_idx < fdw->nfiles * 2); - - if (fdw->kqrevents[event_idx].ident != fd) - return 0; - - if (fdw->kqrevents[event_idx].flags & EV_ERROR) - return FDW_EOF; - - if (fdw->kqrevents[event_idx].flags & EV_EOF) - return FDW_EOF; - - if (fdw->kqrevents[event_idx].filter == EVFILT_READ) - { - if (fdw->fd_rw[fd] & FDW_READ) - return FDW_READ; - } - else if (fdw->kqrevents[event_idx].filter == EVFILT_WRITE) - { - if (fdw->fd_rw[fd] & FDW_WRITE) - { - if (fdw->fd_rw[fd] & FDW_WRITE_ONESHOT) - fdw->fd_rw[fd] &= ~FDW_WRITE; - - return FDW_WRITE; - } - } - else - sys_err("fdwatch_check_event: Unknown filter %d (descriptor %d)", fdw->kqrevents[event_idx].filter, fd); - - return 0; -} - -int fdwatch_get_ident(LPFDWATCH fdw, unsigned int event_idx) -{ - assert(event_idx < fdw->nfiles * 2); - return fdw->kqrevents[event_idx].ident; -} - -int fdwatch_get_buffer_size(LPFDWATCH fdw, socket_t fd) -{ - int event_idx = fdw->fd_event_idx[fd]; - - if (fdw->kqrevents[event_idx].filter == EVFILT_WRITE) - return fdw->kqrevents[event_idx].data; - - return 0; -} - -void * fdwatch_get_client_data(LPFDWATCH fdw, unsigned int event_idx) -{ - int fd; - - assert(event_idx < fdw->nfiles * 2); - - fd = fdw->kqrevents[event_idx].ident; - - if (fd >= fdw->nfiles) - return NULL; - - return (fdw->fd_data[fd]); -} -#else // ifndef __USE_SELECT__ - -#ifdef __WIN32__ -static int win32_init_refcount = 0; - -static bool win32_init() -{ - if (win32_init_refcount > 0) - { - win32_init_refcount++; - return true; - } - - WORD wVersion = MAKEWORD(2, 0); - WSADATA wsaData; - - if (WSAStartup(wVersion, &wsaData) != 0) - return false; - - win32_init_refcount++; - return true; -} - -static void win32_deinit() -{ - if (--win32_init_refcount <= 0) - WSACleanup(); -} -#endif - -LPFDWATCH fdwatch_new(int nfiles) -{ - LPFDWATCH fdw; - -#ifdef __WIN32__ - if (!win32_init()) - return NULL; -#endif - // nfiles value is limited to FD_SETSIZE (64) - CREATE(fdw, FDWATCH, 1); - fdw->nfiles = MIN(nfiles, FD_SETSIZE); - - FD_ZERO(&fdw->rfd_set); - FD_ZERO(&fdw->wfd_set); - - CREATE(fdw->select_fds, socket_t, nfiles); - CREATE(fdw->select_rfdidx, int, nfiles); - - fdw->nselect_fds = 0; - - CREATE(fdw->fd_rw, int, nfiles); - CREATE(fdw->fd_data, void*, nfiles); - - return (fdw); -} - -void fdwatch_delete(LPFDWATCH fdw) -{ - free(fdw->fd_data); - free(fdw->fd_rw); - free(fdw->select_fds); - free(fdw->select_rfdidx); - free(fdw); - -#ifdef __WIN32__ - win32_deinit(); -#endif -} - -static int fdwatch_get_fdidx(LPFDWATCH fdw, socket_t fd) { - int i; - for (i = 0; i < fdw->nselect_fds; ++i) { - if (fdw->select_fds[i] == fd) { - return i; - } - } - return -1; -} - -void fdwatch_add_fd(LPFDWATCH fdw, socket_t fd, void* client_data, int rw, int oneshot) -{ - int idx = fdwatch_get_fdidx(fdw, fd); - if (idx < 0) { - if (fdw->nselect_fds >= fdw->nfiles) { - return; - } - idx = fdw->nselect_fds; - fdw->select_fds[fdw->nselect_fds++] = fd; - fdw->fd_rw[idx] = rw; - } else { - fdw->fd_rw[idx] |= rw; - } - fdw->fd_data[idx] = client_data; - - if (rw & FDW_READ) - FD_SET(fd, &fdw->rfd_set); - - if (rw & FDW_WRITE) - FD_SET(fd, &fdw->wfd_set); -} - -void fdwatch_del_fd(LPFDWATCH fdw, socket_t fd) -{ - if (fdw->nselect_fds <= 0) { - return; - } - int idx = fdwatch_get_fdidx(fdw, fd); - if (idx < 0) { - return; - } - - --fdw->nselect_fds; - - fdw->select_fds[idx] = fdw->select_fds[fdw->nselect_fds]; - fdw->fd_data[idx] = fdw->fd_data[fdw->nselect_fds]; - fdw->fd_rw[idx] = fdw->fd_rw[fdw->nselect_fds]; - - FD_CLR(fd, &fdw->rfd_set); - FD_CLR(fd, &fdw->wfd_set); -} - -int fdwatch(LPFDWATCH fdw, struct timeval *timeout) -{ - int r, i, event_idx; - struct timeval tv; - - fdw->working_rfd_set = fdw->rfd_set; - fdw->working_wfd_set = fdw->wfd_set; - - if (!timeout) - { - tv.tv_sec = 0; - tv.tv_usec = 0; - r = select(0, &fdw->working_rfd_set, &fdw->working_wfd_set, (fd_set*) 0, &tv); - } - else - { - tv = *timeout; - r = select(0, &fdw->working_rfd_set, &fdw->working_wfd_set, (fd_set*) 0, &tv); - } - - if (r == -1) - return -1; - - event_idx = 0; - - for (i = 0; i < fdw->nselect_fds; ++i) - { - if (fdwatch_check_fd(fdw, fdw->select_fds[i])) - fdw->select_rfdidx[event_idx++] = i; - } - - return event_idx; -} - -int fdwatch_check_fd(LPFDWATCH fdw, socket_t fd) -{ - int idx = fdwatch_get_fdidx(fdw, fd); - if (idx < 0) { - return 0; - } - int result = 0; - if ((fdw->fd_rw[idx] & FDW_READ) && FD_ISSET(fd, &fdw->working_rfd_set)) { - result |= FDW_READ; - } - if ((fdw->fd_rw[idx] & FDW_WRITE) && FD_ISSET(fd, &fdw->working_wfd_set)) { - result |= FDW_WRITE; - } - return result; -} - -void * fdwatch_get_client_data(LPFDWATCH fdw, unsigned int event_idx) -{ - int idx = fdw->select_rfdidx[event_idx]; - if (idx < 0 || fdw->nfiles <= idx) { - return NULL; - } - return fdw->fd_data[idx]; -} - -int fdwatch_get_ident(LPFDWATCH fdw, unsigned int event_idx) -{ - int idx = fdw->select_rfdidx[event_idx]; - if (idx < 0 || fdw->nfiles <= idx) { - return 0; - } - return (int)fdw->select_fds[idx]; -} - -void fdwatch_clear_event(LPFDWATCH fdw, socket_t fd, unsigned int event_idx) -{ - int idx = fdw->select_rfdidx[event_idx]; - if (idx < 0 || fdw->nfiles <= idx) { - return; - } - socket_t rfd = fdw->select_fds[idx]; - if (fd != rfd) { - return; - } - FD_CLR(fd, &fdw->working_rfd_set); - FD_CLR(fd, &fdw->working_wfd_set); -} - -int fdwatch_check_event(LPFDWATCH fdw, socket_t fd, unsigned int event_idx) -{ - int idx = fdw->select_rfdidx[event_idx]; - if (idx < 0 || fdw->nfiles <= idx) { - return 0; - } - socket_t rfd = fdw->select_fds[idx]; - if (fd != rfd) { - return 0; - } - int result = fdwatch_check_fd(fdw, fd); - if (result & FDW_READ) { - return FDW_READ; - } else if (result & FDW_WRITE) { - return FDW_WRITE; - } - return 0; -} - -int fdwatch_get_buffer_size(LPFDWATCH fdw, socket_t fd) -{ - return INT_MAX; // XXX TODO -} - -#endif diff --git a/libthecore/src/log.cpp b/libthecore/src/log.cpp index 51485c5..979b72d 100644 --- a/libthecore/src/log.cpp +++ b/libthecore/src/log.cpp @@ -42,7 +42,7 @@ void log_file_rotate(LPLOGFILE logfile); void log_file_check(LPLOGFILE logfile); void log_file_set_dir(const char *dir); -static unsigned int log_level_bits = 0; +static unsigned int log_level_bits = 7; void log_set_level(unsigned int bit) { diff --git a/libthecore/src/main.cpp b/libthecore/src/main.cpp index c7f96d3..dcac751 100644 --- a/libthecore/src/main.cpp +++ b/libthecore/src/main.cpp @@ -8,11 +8,9 @@ #include "stdafx.h" #include "memory.h" -extern void GOST_Init(); - LPHEART thecore_heart = NULL; -volatile int shutdowned = FALSE; +volatile int shutdowned = false; volatile int tics = 0; unsigned int thecore_profiler[NUM_PF]; @@ -67,7 +65,7 @@ int thecore_init(int fps, HEARTFUNC heartbeat_func) void thecore_shutdown() { - shutdowned = TRUE; + shutdowned = true; } int thecore_idle(void) diff --git a/libthecore/src/signal.cpp b/libthecore/src/signals.cpp similarity index 98% rename from libthecore/src/signal.cpp rename to libthecore/src/signals.cpp index 8acdcef..e6271b2 100644 --- a/libthecore/src/signal.cpp +++ b/libthecore/src/signals.cpp @@ -35,7 +35,7 @@ RETSIGTYPE checkpointing(int sig) RETSIGTYPE hupsig(int sig) { - shutdowned = TRUE; + shutdowned = true; sys_err("SIGHUP, SIGINT, SIGTERM signal has been received. shutting down."); } diff --git a/libthecore/src/socket.cpp b/libthecore/src/socket.cpp deleted file mode 100644 index cfc3f2f..0000000 --- a/libthecore/src/socket.cpp +++ /dev/null @@ -1,555 +0,0 @@ -/* - * Filename: socket.c - * Description: ¼ÒÄÏ °ü·Ã ¼Ò½º. - * - * Author: ºñ¿± aka. Cronan - */ -#define __LIBTHECORE__ -#include "stdafx.h" - -/* Forwards */ -void socket_lingeron(socket_t s); -void socket_lingeroff(socket_t s); -void socket_timeout(socket_t s, long sec, long usec); -void socket_reuse(socket_t s); -void socket_keepalive(socket_t s); - -int socket_udp_read(socket_t desc, char * read_point, size_t space_left, struct sockaddr * from, socklen_t * fromlen) -{ - /* - ssize_t recvfrom(int s, void * buf, size_t len, int flags, struct sockaddr * from, socklen_t * fromlen); - */ - ssize_t ret; - ret = recvfrom(desc, read_point, space_left, 0, from, fromlen); - return (ret); -} - -int socket_read(socket_t desc, char* read_point, size_t space_left) -{ - int ret; - - ret = recv(desc, read_point, space_left, 0); - - if (ret > 0) - return ret; - - if (ret == 0) // Á¤»óÀûÀ¸·Î Á¢¼Ó ²÷±è - return -1; - -#ifdef EINTR /* Interrupted system call - various platforms */ - if (errno == EINTR) - return (0); -#endif - -#ifdef EAGAIN /* POSIX */ - if (errno == EAGAIN) - return (0); -#endif - -#ifdef EWOULDBLOCK /* BSD */ - if (errno == EWOULDBLOCK) - return (0); -#endif /* EWOULDBLOCK */ - -#ifdef EDEADLK /* Macintosh */ - if (errno == EDEADLK) - return (0); -#endif - -#ifdef __WIN32__ - int wsa_error = WSAGetLastError(); - if (wsa_error == WSAEWOULDBLOCK) { - return 0; - } - sys_log(0, "socket_read: WSAGetLastError returned %d", wsa_error); -#endif - - sys_err("about to lose connection"); - return -1; -} - - -int socket_write_tcp(socket_t desc, const char *txt, int length) -{ - int bytes_written = send(desc, txt, length, 0); - - // ¼º°ø - if (bytes_written > 0) - return (bytes_written); - - if (bytes_written == 0) - return -1; - -#ifdef EAGAIN /* POSIX */ - if (errno == EAGAIN) - return 0; -#endif - -#ifdef EWOULDBLOCK /* BSD */ - if (errno == EWOULDBLOCK) - return 0; -#endif - -#ifdef EDEADLK /* Macintosh */ - if (errno == EDEADLK) - return 0; -#endif - -#ifdef __WIN32__ - int wsa_error = WSAGetLastError(); - if (wsa_error == WSAEWOULDBLOCK) { - return 0; - } - sys_log(0, "socket_write_tcp: WSAGetLastError returned %d", wsa_error); -#endif - - /* Looks like the error was fatal. Too bad. */ - return -1; -} - - -int socket_write(socket_t desc, const char *data, size_t length) -{ - size_t total; - int bytes_written; - - total = length; - - do - { - if ((bytes_written = socket_write_tcp(desc, data, total)) < 0) - { -#ifdef EWOULDBLOCK - if (errno == EWOULDBLOCK) - errno = EAGAIN; -#endif - if (errno == EAGAIN) - sys_err("socket write would block, about to close!"); - else - sys_err("write to desc error"); // 'º¸Åë' »ó´ëÆíÀ¸·Î ºÎÅÍ Á¢¼ÓÀÌ ²÷±ä °ÍÀÌ´Ù. - - return -1; - } - else - { - data += bytes_written; - total -= bytes_written; - } - } - while (total > 0); - - return 0; -} - -int socket_bind(const char * ip, int port, int protocol) -{ - int s; -#ifdef __WIN32 - SOCKADDR_IN sa; -#else - struct sockaddr_in sa; -#endif - - if ((s = socket(AF_INET, protocol, 0)) < 0) - { - sys_err("socket: %s", strerror(errno)); - return -1; - } - - socket_reuse(s); -#ifndef __linux__ -#if defined(WIN32) - // Winsock2: SO_DONTLINGER, SO_KEEPALIVE, SO_LINGER, and SO_OOBINLINE are - // not supported on sockets of type SOCK_DGRAM - if (protocol == SOCK_STREAM) { - socket_lingeroff(s); - } -#else - socket_lingeroff(s); -#endif -#endif - - memset(&sa, 0, sizeof(sa)); - sa.sin_family = AF_INET; -//À©µµ¿ì ¼­¹ö´Â °³¹ß¿ëÀ¸·Î¸¸ ¾²±â ¶§¹®¿¡ BIND ip¸¦ INADDR_ANY·Î °íÁ¤ -//(Å×½ºÆ®ÀÇ ÆíÀǼºÀ» À§ÇØ) -#ifndef __WIN32__ - sa.sin_addr.s_addr = inet_addr(ip); -#else - sa.sin_addr.s_addr = INADDR_ANY; -#endif - sa.sin_port = htons((unsigned short) port); - - if (bind(s, (struct sockaddr *) &sa, sizeof(sa)) < 0) - { - sys_err("bind: %s", strerror(errno)); - return -1; - } -#ifndef __linux__ - socket_nonblock(s); -#endif - - if (protocol == SOCK_STREAM) - { - sys_log(0, "SYSTEM: BINDING TCP PORT ON [%d] (fd %d)", port, s); - listen(s, SOMAXCONN); - } - else - sys_log(0, "SYSTEM: BINDING UDP PORT ON [%d] (fd %d)", port, s); - - return s; -} - -int socket_tcp_bind(const char * ip, int port) -{ - return socket_bind(ip, port, SOCK_STREAM); -} - -int socket_udp_bind(const char * ip, int port) -{ - return socket_bind(ip, port, SOCK_DGRAM); -} - -void socket_close(socket_t s) -{ -#ifdef __WIN32__ - closesocket(s); -#else - close(s); -#endif -} - -socket_t socket_accept(socket_t s, struct sockaddr_in *peer) -{ - socket_t desc; - socklen_t i; - - i = sizeof(*peer); - - if ((desc = accept(s, (struct sockaddr *) peer, &i)) == -1) - { - sys_err("accept: %s (fd %d)", strerror(errno), s); - return -1; - } - - if (desc >= 65500) - { - sys_err("SOCKET FD 65500 LIMIT! %d", desc); - socket_close(s); - return -1; - } -#ifndef __linux__ - socket_nonblock(desc); - socket_lingeroff(desc); -#endif - return (desc); -} - -socket_t socket_connect(const char* host, WORD port) -{ - socket_t s = 0; - struct sockaddr_in server_addr; - int rslt; - - /* ¼ÒÄÏÁÖ¼Ò ±¸Á¶Ã¼ ÃʱâÈ­ */ - memset(&server_addr, 0, sizeof(server_addr)); - - if (isdigit(*host)) - server_addr.sin_addr.s_addr = inet_addr(host); - else - { - struct hostent *hp; - - if ((hp = gethostbyname(host)) == NULL) - { - sys_err("socket_connect(): can not connect to %s:%d", host, port); - return -1; - } - - memcpy((char* ) &server_addr.sin_addr, hp->h_addr, sizeof(server_addr.sin_addr)); - } - - server_addr.sin_family = AF_INET; - server_addr.sin_port = htons(port); - - if ((s = socket(AF_INET, SOCK_STREAM, 0)) < 0) - { - perror("socket"); - return -1; - } - - socket_keepalive(s); - socket_sndbuf(s, 233016); - socket_rcvbuf(s, 233016); - socket_timeout(s, 10, 0); - socket_lingeron(s); - - /* ¿¬°á¿äû */ - if ((rslt = connect(s, (struct sockaddr *) &server_addr, sizeof(server_addr))) < 0) - { - socket_close(s); - -#ifdef __WIN32__ - switch (WSAGetLastError()) -#else - switch (rslt) -#endif - { -#ifdef __WIN32__ - case WSAETIMEDOUT: -#else - case EINTR: -#endif - sys_err("HOST %s:%d connection timeout.", host, port); - break; -#ifdef __WIN32__ - case WSAECONNREFUSED: -#else - case ECONNREFUSED: -#endif - sys_err("HOST %s:%d port is not opened. connection refused.", host, port); - break; -#ifdef __WIN32__ - case WSAENETUNREACH: -#else - case ENETUNREACH: -#endif - sys_err("HOST %s:%d is not reachable from this host.", host, port); - break; - - default: - sys_err("HOST %s:%d, could not connect.", host, port); - break; - } - - perror("connect"); - return (-1); - } - - return (s); -} - -#ifndef __WIN32__ - -#ifndef O_NONBLOCK -#define O_NONBLOCK O_NDELAY -#endif - -void socket_nonblock(socket_t s) -{ - int flags; - - flags = fcntl(s, F_GETFL, 0); - flags |= O_NONBLOCK; - - if (fcntl(s, F_SETFL, flags) < 0) - { - sys_err("fcntl: nonblock: %s", strerror(errno)); - return; - } -} - -void socket_block(socket_t s) -{ - int flags; - - flags = fcntl(s, F_GETFL, 0); - flags &= ~O_NONBLOCK; - - if (fcntl(s, F_SETFL, flags) < 0) - { - sys_err("fcntl: nonblock: %s", strerror(errno)); - return; - } -} -#else -void socket_nonblock(socket_t s) -{ - unsigned long val = 1; - ioctlsocket(s, FIONBIO, &val); -} - -void socket_block(socket_t s) -{ - unsigned long val = 0; - ioctlsocket(s, FIONBIO, &val); -} -#endif - -void socket_dontroute(socket_t s) -{ - int set; - - if (setsockopt(s, SOL_SOCKET, SO_DONTROUTE, (const char *) &set, sizeof(int)) < 0) - { - sys_err("setsockopt: dontroute: %s", strerror(errno)); - socket_close(s); - return; - } -} - -void socket_lingeroff(socket_t s) -{ -#if defined(__WIN32__) - int linger; - linger = 0; -#else - struct linger linger; - - linger.l_onoff = 0; - linger.l_linger = 0; -#endif - if (setsockopt(s, SOL_SOCKET, SO_LINGER, (const char*) &linger, sizeof(linger)) < 0) - { - sys_err("setsockopt: linger: %s", strerror(errno)); - socket_close(s); - return; - } -} - -void socket_lingeron(socket_t s) -{ -#if defined(__WIN32__) - int linger; - linger = 0; -#else - struct linger linger; - - linger.l_onoff = 1; - linger.l_linger = 0; -#endif - if (setsockopt(s, SOL_SOCKET, SO_LINGER, (const char*) &linger, sizeof(linger)) < 0) - { - sys_err("setsockopt: linger: %s", strerror(errno)); - socket_close(s); - return; - } -} - -void socket_rcvbuf(socket_t s, unsigned int opt) -{ - socklen_t optlen; - - optlen = sizeof(opt); - - if (setsockopt(s, SOL_SOCKET, SO_RCVBUF, (const char*) &opt, optlen) < 0) - { - sys_err("setsockopt: rcvbuf: %s", strerror(errno)); - socket_close(s); - return; - } - - opt = 0; - optlen = sizeof(opt); - - if (getsockopt(s, SOL_SOCKET, SO_RCVBUF, (char*) &opt, &optlen) < 0) - { - sys_err("getsockopt: rcvbuf: %s", strerror(errno)); - socket_close(s); - return; - } - - sys_log(1, "SYSTEM: %d: receive buffer changed to %d", s, opt); -} - -void socket_sndbuf(socket_t s, unsigned int opt) -{ - socklen_t optlen; - - optlen = sizeof(opt); - - if (setsockopt(s, SOL_SOCKET, SO_SNDBUF, (const char*) &opt, optlen) < 0) - { - sys_err("setsockopt: sndbuf: %s", strerror(errno)); - return; - } - - opt = 0; - optlen = sizeof(opt); - - if (getsockopt(s, SOL_SOCKET, SO_SNDBUF, (char*) &opt, &optlen) < 0) - { - sys_err("getsockopt: sndbuf: %s", strerror(errno)); - return; - } - - sys_log(1, "SYSTEM: %d: send buffer changed to %d", s, opt); -} - -// sec : seconds, usec : microseconds -void socket_timeout(socket_t s, long sec, long usec) -{ -#ifndef __WIN32__ - struct timeval rcvopt; - struct timeval sndopt; - socklen_t optlen = sizeof(rcvopt); - - rcvopt.tv_sec = sndopt.tv_sec = sec; - rcvopt.tv_usec = sndopt.tv_usec = usec; -#else - socklen_t rcvopt, sndopt; - socklen_t optlen = sizeof(rcvopt); - sndopt = rcvopt = (sec * 1000) + (usec / 1000); -#endif - -#ifndef __linux__ - if (setsockopt(s, SOL_SOCKET, SO_RCVTIMEO, (const char*) &rcvopt, optlen) < 0) - { - sys_err("setsockopt: timeout: %s", strerror(errno)); - socket_close(s); - return; - } - - if (getsockopt(s, SOL_SOCKET, SO_RCVTIMEO, (char*) &rcvopt, &optlen) < 0) - { - sys_err("getsockopt: timeout: %s", strerror(errno)); - socket_close(s); - return; - } -#endif - - optlen = sizeof(sndopt); -#ifndef __linux__ - if (setsockopt(s, SOL_SOCKET, SO_SNDTIMEO, (const char*) &sndopt, optlen) < 0) - { - sys_err("setsockopt: timeout: %s", strerror(errno)); - socket_close(s); - return; - } - - if (getsockopt(s, SOL_SOCKET, SO_SNDTIMEO, (char*) &sndopt, &optlen) < 0) - { - sys_err("getsockopt: timeout: %s", strerror(errno)); - socket_close(s); - return; - } -#endif - -#ifndef __WIN32__ - sys_log(1, "SYSTEM: %d: TIMEOUT RCV: %d.%d, SND: %d.%d", s, rcvopt.tv_sec, rcvopt.tv_usec, sndopt.tv_sec, sndopt.tv_usec); -#endif -} - -void socket_reuse(socket_t s) -{ - int opt = 1; - - if (setsockopt(s, SOL_SOCKET, SO_REUSEADDR, (const char*) &opt, sizeof(opt)) < 0) - { - sys_err("setsockopt: reuse: %s", strerror(errno)); - socket_close(s); - return; - } -} - -void socket_keepalive(socket_t s) -{ - int opt = 1; - - if (setsockopt(s, SOL_SOCKET, SO_KEEPALIVE, (const char*) &opt, sizeof(opt)) < 0) - { - perror("setsockopt: keepalive"); - socket_close(s); - return; - } -} diff --git a/libthecore/src/utils.cpp b/libthecore/src/utils.cpp index db2ef21..49bf6e0 100644 --- a/libthecore/src/utils.cpp +++ b/libthecore/src/utils.cpp @@ -262,7 +262,7 @@ void parse_token(char *src, char *token, char *value) struct tm * tm_calc(const struct tm * curr_tm, int days) { - char yoon = FALSE; + bool yoon = false; static struct tm new_tm; int monthdays[12] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 }; @@ -281,10 +281,10 @@ struct tm * tm_calc(const struct tm * curr_tm, int days) if (!((new_tm.tm_year + 1900) % 100)) { if (!((new_tm.tm_year + 1900) % 400)) - yoon = TRUE; + yoon = true; } else - yoon = TRUE; + yoon = true; } if (yoon)