mirror of
https://github.com/dhewm/dhewm3.git
synced 2025-01-19 07:51:54 +00:00
Rename game libraries to the game name
Never use "game" as library name, use the game name instead. This allows d3xp/mods to coexist in a single (installation-)directory. This paves the way for future `make install` or binary installers. Additionally, the "mods" menu entry works from within the game gui.
This commit is contained in:
parent
822f9d30b5
commit
be37221024
2 changed files with 15 additions and 12 deletions
|
@ -6,8 +6,6 @@ cmake_minimum_required(VERSION 2.6)
|
|||
# osx: place game .dylib's in the bundle (next to the binary)
|
||||
# osx: -weak_framework ?
|
||||
|
||||
# how to name the game .so's?
|
||||
|
||||
# maybe add these as options:
|
||||
# BUILD_GAMEPAK
|
||||
# TARGET_MONO
|
||||
|
@ -27,7 +25,7 @@ include(CheckCXXCompilerFlag)
|
|||
include(CheckFunctionExists)
|
||||
|
||||
option(CORE "Build the core" ON)
|
||||
option(GAME "Build the base game code" ON)
|
||||
option(BASE "Build the base game code" ON)
|
||||
option(D3XP "Build the d3xp game code" OFF)
|
||||
option(DEDICATED "Build the dedicated server" OFF)
|
||||
option(X86 "Cross compile for x86 (only applicable on x86_64)" OFF)
|
||||
|
@ -765,14 +763,14 @@ if (DEDICATED)
|
|||
)
|
||||
endif()
|
||||
|
||||
if (GAME)
|
||||
add_library(game SHARED ${src_game})
|
||||
set_target_properties(game PROPERTIES PREFIX "")
|
||||
set_target_properties(game PROPERTIES COMPILE_DEFINITIONS "GAME_DLL")
|
||||
set_target_properties(game PROPERTIES COMPILE_FLAGS "-I${CMAKE_SOURCE_DIR}/game")
|
||||
set_target_properties(game PROPERTIES LINK_FLAGS "${ldflags}")
|
||||
set_target_properties(game PROPERTIES INSTALL_NAME_DIR "@executable_path")
|
||||
target_link_libraries(game idlib)
|
||||
if (BASE)
|
||||
add_library(base SHARED ${src_game})
|
||||
set_target_properties(base PROPERTIES PREFIX "")
|
||||
set_target_properties(base PROPERTIES COMPILE_DEFINITIONS "GAME_DLL")
|
||||
set_target_properties(base PROPERTIES COMPILE_FLAGS "-I${CMAKE_SOURCE_DIR}/game")
|
||||
set_target_properties(base PROPERTIES LINK_FLAGS "${ldflags}")
|
||||
set_target_properties(base PROPERTIES INSTALL_NAME_DIR "@executable_path")
|
||||
target_link_libraries(base idlib)
|
||||
endif()
|
||||
|
||||
if (D3XP)
|
||||
|
|
|
@ -2589,6 +2589,7 @@ idCommonLocal::LoadGameDLL
|
|||
*/
|
||||
void idCommonLocal::LoadGameDLL( void ) {
|
||||
#ifdef __DOOM_DLL__
|
||||
const char *fs_game;
|
||||
char dll[MAX_OSPATH];
|
||||
idStr s;
|
||||
|
||||
|
@ -2596,8 +2597,12 @@ void idCommonLocal::LoadGameDLL( void ) {
|
|||
gameExport_t gameExport;
|
||||
GetGameAPI_t GetGameAPI;
|
||||
|
||||
fs_game = cvarSystem->GetCVarString("fs_game");
|
||||
if (!fs_game || !fs_game[0])
|
||||
fs_game = BASE_GAMEDIR;
|
||||
|
||||
gameDLL = 0;
|
||||
sys->DLL_GetFileName("game", dll, sizeof(dll));
|
||||
sys->DLL_GetFileName(fs_game, dll, sizeof(dll));
|
||||
|
||||
// try next to the binary first (build tree)
|
||||
if (Sys_GetPath(PATH_EXE, s)) {
|
||||
|
|
Loading…
Reference in a new issue