Skip to content

Commit

Permalink
Enable unity build to speed up compilation
Browse files Browse the repository at this point in the history
  • Loading branch information
MillhioreBT committed Dec 13, 2023
1 parent f52b7dc commit af68e33
Show file tree
Hide file tree
Showing 7 changed files with 146 additions and 121 deletions.
6 changes: 1 addition & 5 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,6 @@ jobs:
test:
runs-on: ubuntu-latest

env:
CC: gcc
CXX: g++

steps:
- uses: actions/checkout@v3

Expand All @@ -29,5 +25,5 @@ jobs:
with:
buildPreset: default
configurePreset: default
configurePresetAdditionalArgs: "['-G Ninja', '-DENABLE_TESTING=ON']"
configurePresetAdditionalArgs: "['-G Ninja', '-DBUILD_TESTING=ON']"
testPreset: default
5 changes: 3 additions & 2 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ find_package(Lua54 REQUIRED)

find_package(Boost 1.66.0 REQUIRED COMPONENTS system iostreams)

option(ENABLE_TESTING "Build unit tests" OFF)
option(BUILD_TESTING "Build unit tests" OFF)

include_directories(${Boost_INCLUDE_DIRS} ${Crypto++_INCLUDE_DIR} ${LUA_INCLUDE_DIR} ${MYSQL_INCLUDE_DIR} ${PUGIXML_INCLUDE_DIR})

Expand All @@ -65,7 +65,8 @@ add_subdirectory(src)
add_executable(tfs ${tfs_MAIN})
target_link_libraries(tfs tfslib)

if (ENABLE_TESTING)
if (BUILD_TESTING)
message(STATUS "Building unit tests")
enable_testing()
add_subdirectory(src/tests)
endif()
Expand Down
4 changes: 3 additions & 1 deletion src/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ set(tfs_SRC
${CMAKE_CURRENT_LIST_DIR}/movement.cpp
${CMAKE_CURRENT_LIST_DIR}/networkmessage.cpp
${CMAKE_CURRENT_LIST_DIR}/npc.cpp
${CMAKE_CURRENT_LIST_DIR}/otserv.cpp
${CMAKE_CURRENT_LIST_DIR}/outfit.cpp
${CMAKE_CURRENT_LIST_DIR}/outputmessage.cpp
${CMAKE_CURRENT_LIST_DIR}/party.cpp
Expand Down Expand Up @@ -156,6 +157,7 @@ set(tfs_HDR
${CMAKE_CURRENT_LIST_DIR}/movement.h
${CMAKE_CURRENT_LIST_DIR}/networkmessage.h
${CMAKE_CURRENT_LIST_DIR}/npc.h
${CMAKE_CURRENT_LIST_DIR}/otserv.h
${CMAKE_CURRENT_LIST_DIR}/outfit.h
${CMAKE_CURRENT_LIST_DIR}/outputmessage.h
${CMAKE_CURRENT_LIST_DIR}/party.h
Expand Down Expand Up @@ -192,7 +194,7 @@ set(tfs_HDR
${CMAKE_CURRENT_LIST_DIR}/xtea.h
${tfs_luamodules_HDR})
set(tfs_MAIN ${CMAKE_CURRENT_LIST_DIR}/otserv.cpp PARENT_SCOPE)
set(tfs_MAIN ${CMAKE_CURRENT_LIST_DIR}/main.cpp PARENT_SCOPE)
add_library(tfslib ${tfs_SRC})
include_directories(/usr/include/lua5.4)
Expand Down
50 changes: 50 additions & 0 deletions src/main.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
#include "otpch.h"

#include "configmanager.h"
#include "otserv.h"
#include "tools.h"

extern ConfigManager g_config;

static bool argumentsHandler(const std::vector<std::string_view>& args)
{
for (const auto& arg : args) {
if (arg == "--help") {
std::clog << "Usage:\n"
"\n"
"\t--config=$1\t\tAlternate configuration file path.\n"
"\t--ip=$1\t\t\tIP address of the server.\n"
"\t\t\t\tShould be equal to the global IP.\n"
"\t--login-port=$1\tPort for login server to listen on.\n"
"\t--game-port=$1\tPort for game server to listen on.\n";
return false;
} else if (arg == "--version") {
printServerVersion();
return false;
}

auto tmp = explodeString(arg, "=");

if (tmp[0] == "--config")
g_config.setString(ConfigKeysString::CONFIG_FILE, tmp[1]);
else if (tmp[0] == "--ip")
g_config.setString(ConfigKeysString::IP, tmp[1]);
else if (tmp[0] == "--login-port")
g_config.setInteger(ConfigKeysInteger::LOGIN_PORT, std::stoi(tmp[1].data()));
else if (tmp[0] == "--game-port")
g_config.setInteger(ConfigKeysInteger::GAME_PORT, std::stoi(tmp[1].data()));
}

return true;
}

int main(int argc, const char** argv)
{
std::vector<std::string_view> args(argv, argv + argc);
if (!argumentsHandler(args)) {
return 1;
}

startServer();
return 0;
}
191 changes: 78 additions & 113 deletions src/otserv.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@

#include "otpch.h"

#include "otserv.h"

#include "configmanager.h"
#include "databasemanager.h"
#include "databasetasks.h"
Expand Down Expand Up @@ -37,100 +39,15 @@ std::mutex g_loaderLock;
std::condition_variable g_loaderSignal;
std::unique_lock<std::mutex> g_loaderUniqueLock(g_loaderLock);

namespace {

void startupErrorMessage(std::string_view errorStr)
{
std::cout << "> ERROR: " << errorStr << std::endl;
g_loaderSignal.notify_all();
}

void mainLoader(int argc, char* argv[], ServiceManager* services);
bool argumentsHandler(const StringVector& args);

[[noreturn]] void badAllocationHandler()
{
// Use functions that only use stack allocation
puts("Allocation failed, server out of memory.\nDecrease the size of your map or compile in 64 bits mode.\n");
getchar();
exit(-1);
}

int main(int argc, char* argv[])
{
StringVector args = StringVector(argv, argv + argc);
if (argc > 1 && !argumentsHandler(args)) {
return 0;
}

// Setup bad allocation handler
std::set_new_handler(badAllocationHandler);

ServiceManager serviceManager;

g_dispatcher.start();
g_scheduler.start();

g_dispatcher.addTask([=, services = &serviceManager]() { mainLoader(argc, argv, services); });

g_loaderSignal.wait(g_loaderUniqueLock);

if (serviceManager.is_running()) {
std::cout << ">> " << g_config[ConfigKeysString::SERVER_NAME] << " Server Online!" << std::endl << std::endl;
serviceManager.run();
} else {
std::cout << ">> No services running. The server is NOT online." << std::endl;
g_scheduler.shutdown();
g_databaseTasks.shutdown();
g_dispatcher.shutdown();
}

g_scheduler.join();
g_databaseTasks.join();
g_dispatcher.join();
return 0;
}

void printServerVersion()
{
#if defined(GIT_RETRIEVED_STATE) && GIT_RETRIEVED_STATE
std::cout << STATUS_SERVER_NAME << " - Version " << GIT_DESCRIBE << std::endl;
std::cout << "Git SHA1 " << GIT_SHORT_SHA1 << " dated " << GIT_COMMIT_DATE_ISO8601 << std::endl;
#if GIT_IS_DIRTY
std::cout << "*** DIRTY - NOT OFFICIAL RELEASE ***" << std::endl;
#endif
#else
std::cout << STATUS_SERVER_NAME << " - Version " << STATUS_SERVER_VERSION << std::endl;
#endif
std::cout << std::endl;

std::cout << "Compiled with " << BOOST_COMPILER << std::endl;
std::cout << "Compiled on " << __DATE__ << ' ' << __TIME__ << " for platform ";
#if defined(__amd64__) || defined(_M_X64)
std::cout << "x64" << std::endl;
#elif defined(__i386__) || defined(_M_IX86) || defined(_X86_)
std::cout << "x86" << std::endl;
#elif defined(__arm__)
std::cout << "ARM" << std::endl;
#else
std::cout << "unknown" << std::endl;
#endif
#if defined(LUAJIT_VERSION)
std::cout << "Linked with " << LUAJIT_VERSION << " for Lua support" << std::endl;
#else
std::cout << "Linked with " << LUA_RELEASE << " for Lua support" << std::endl;
#endif
std::cout << std::endl;

std::cout << "A server developed by " << STATUS_SERVER_DEVELOPERS << std::endl;
std::cout << "Downgraded and further developed by Nekiro / MillhioreBT" << std::endl;
std::cout << "Visit our forum for updates, support, and resources: http://otland.net/." << std::endl;
std::cout << std::endl;

std::cout << "Repository: " << fmt::format(fg(fmt::color::floral_white), "{}", STATUS_SERVER_REPOSITORY)
<< std::endl;
std::cout << std::endl;
}

void mainLoader(int, char*[], ServiceManager* services)
void mainLoader(ServiceManager* services)
{
// dispatcher thread
g_game.setGameState(GAME_STATE_STARTUP);
Expand Down Expand Up @@ -329,34 +246,82 @@ void mainLoader(int, char*[], ServiceManager* services)
g_loaderSignal.notify_all();
}

bool argumentsHandler(const StringVector& args)
[[noreturn]] void badAllocationHandler()
{
for (const auto& arg : args) {
if (arg == "--help") {
std::clog << "Usage:\n"
"\n"
"\t--config=$1\t\tAlternate configuration file path.\n"
"\t--ip=$1\t\t\tIP address of the server.\n"
"\t\t\t\tShould be equal to the global IP.\n"
"\t--login-port=$1\tPort for login server to listen on.\n"
"\t--game-port=$1\tPort for game server to listen on.\n";
return false;
} else if (arg == "--version") {
printServerVersion();
return false;
}
// Use functions that only use stack allocation
puts("Allocation failed, server out of memory.\nDecrease the size of your map or compile in 64 bits mode.\n");
getchar();
exit(-1);
}

} // namespace

void startServer()
{
// Setup bad allocation handler
std::set_new_handler(badAllocationHandler);

ServiceManager serviceManager;

auto tmp = explodeString(arg, "=");
g_dispatcher.start();
g_scheduler.start();

g_dispatcher.addTask([=, services = &serviceManager]() { mainLoader(services); });

g_loaderSignal.wait(g_loaderUniqueLock);

if (tmp[0] == "--config")
g_config.setString(ConfigKeysString::CONFIG_FILE, tmp[1]);
else if (tmp[0] == "--ip")
g_config.setString(ConfigKeysString::IP, tmp[1]);
else if (tmp[0] == "--login-port")
g_config.setInteger(ConfigKeysInteger::LOGIN_PORT, std::stoi(tmp[1].data()));
else if (tmp[0] == "--game-port")
g_config.setInteger(ConfigKeysInteger::GAME_PORT, std::stoi(tmp[1].data()));
if (serviceManager.is_running()) {
std::cout << ">> " << g_config[ConfigKeysString::SERVER_NAME] << " Server Online!" << std::endl << std::endl;
serviceManager.run();
} else {
std::cout << ">> No services running. The server is NOT online." << std::endl;
g_scheduler.shutdown();
g_databaseTasks.shutdown();
g_dispatcher.shutdown();
}

return true;
g_scheduler.join();
g_databaseTasks.join();
g_dispatcher.join();
}

void printServerVersion()
{
#if defined(GIT_RETRIEVED_STATE) && GIT_RETRIEVED_STATE
std::cout << STATUS_SERVER_NAME << " - Version " << GIT_DESCRIBE << std::endl;
std::cout << "Git SHA1 " << GIT_SHORT_SHA1 << " dated " << GIT_COMMIT_DATE_ISO8601 << std::endl;
#if GIT_IS_DIRTY
std::cout << "*** DIRTY - NOT OFFICIAL RELEASE ***" << std::endl;
#endif
#else
std::cout << STATUS_SERVER_NAME << " - Version " << STATUS_SERVER_VERSION << std::endl;
#endif
std::cout << std::endl;

std::cout << "Compiled with " << BOOST_COMPILER << std::endl;
std::cout << "Compiled on " << __DATE__ << ' ' << __TIME__ << " for platform ";
#if defined(__amd64__) || defined(_M_X64)
std::cout << "x64" << std::endl;
#elif defined(__i386__) || defined(_M_IX86) || defined(_X86_)
std::cout << "x86" << std::endl;
#elif defined(__arm__)
std::cout << "ARM" << std::endl;
#else
std::cout << "unknown" << std::endl;
#endif
#if defined(LUAJIT_VERSION)
std::cout << "Linked with " << LUAJIT_VERSION << " for Lua support" << std::endl;
#else
std::cout << "Linked with " << LUA_RELEASE << " for Lua support" << std::endl;
#endif
std::cout << std::endl;

std::cout << "A server developed by " << STATUS_SERVER_DEVELOPERS << std::endl;
std::cout << "Downgraded and further developed by Nekiro / MillhioreBT" << std::endl;
std::cout << "Visit our forum for updates, support, and resources: http://otland.net/." << std::endl;
std::cout << std::endl;

std::cout << "Repository: " << fmt::format(fg(fmt::color::floral_white), "{}", STATUS_SERVER_REPOSITORY)
<< std::endl;
std::cout << std::endl;
}
10 changes: 10 additions & 0 deletions src/otserv.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
// Copyright 2023 The Forgotten Server Authors. All rights reserved.
// Use of this source code is governed by the GPL-2.0 License that can be found in the LICENSE file.

#ifndef FS_OTSERV_H
#define FS_OTSERV_H

void printServerVersion();
void startServer();

#endif
1 change: 1 addition & 0 deletions vc17/theforgottenserver.vcxproj
Original file line number Diff line number Diff line change
Expand Up @@ -226,6 +226,7 @@
<ClCompile Include="..\src\luaweapons.cpp" />
<ClCompile Include="..\src\luaxml.cpp" />
<ClCompile Include="..\src\mailbox.cpp" />
<ClCompile Include="..\src\main.cpp" />
<ClCompile Include="..\src\map.cpp" />
<ClCompile Include="..\src\matrixarea.cpp" />
<ClCompile Include="..\src\monster.cpp" />
Expand Down

0 comments on commit af68e33

Please sign in to comment.