summaryrefslogtreecommitdiff
path: root/xmake.lua
diff options
context:
space:
mode:
authoromnisci3nce <omniscient.oce@gmail.com>2024-03-05 20:14:38 +1100
committeromnisci3nce <omniscient.oce@gmail.com>2024-03-05 20:14:38 +1100
commitc7bede459cc7d5141f9b0fc5a54868484925b27b (patch)
treec7a35aed3d0201ee8c927d25222f39e62b23ceb8 /xmake.lua
parent7c71005794ee7904ad113d5fff2c7a9aca3cda53 (diff)
trying different linkage on Windows
Diffstat (limited to 'xmake.lua')
-rw-r--r--xmake.lua19
1 files changed, 15 insertions, 4 deletions
diff --git a/xmake.lua b/xmake.lua
index e6b77c2..ba8011f 100644
--- a/xmake.lua
+++ b/xmake.lua
@@ -4,8 +4,6 @@ set_config("cc", "gcc")
add_rules("mode.debug", "mode.release") -- we have two modes: debug & release
-add_syslinks("m") -- these are must have when compiling
-
-- -Wall : base set of warnings
-- -Wextra : additional warnings not covered by -Wall
-- -Wundef : undefined macros
@@ -19,9 +17,11 @@ end
-- Platform defines and system packages
if is_plat("linux") then
add_defines("CEL_PLATFORM_LINUX")
- add_syslinks("dl", "X11")
+ add_syslinks("m", "dl", "X11")
elseif is_plat("windows") then
add_defines("CEL_PLATFORM_WINDOWS")
+ add_syslinks("user32", "gdi32", "kernel32", "shell32")
+ add_links("pthreadVC2-w64")
elseif is_plat("macosx") then
add_defines("CEL_PLATFORM_MAC")
end
@@ -47,7 +47,6 @@ add_requires("local_glfw")
-- common configuration for both static and shared libraries
target("core_config")
set_kind("static") -- kind is required but you can ignore it since it's just for common settings
- add_syslinks("dl")
add_packages("local_glfw")
add_includedirs("deps/glfw-3.3.8/include/GLFW", {public = true})
add_includedirs("deps/glad/include", {public = true})
@@ -72,15 +71,27 @@ target("core_config")
add_files("src/std/*.c")
add_files("src/std/containers/*.c")
add_files("src/systems/*.c")
+
set_default(false) -- prevents standalone building of this target
target("core_static")
set_kind("static")
add_deps("core_config") -- inherit common configurations
+ -- Link against static CRT
+ if is_plat("windows") then
+ add_links("libcmt", "legacy_stdio_definitions") -- for release builds
+ add_links("libcmtd", "legacy_stdio_definitions") -- for debug builds
+ end
target("core_shared")
set_kind("shared")
add_deps("core_config") -- inherit common configurations
+ -- Link against dynamic CRT
+ if is_plat("windows") then
+ add_links("msvcrt", "legacy_stdio_definitions") -- for release builds
+ add_links("msvcrtd", "legacy_stdio_definitions") -- for debug builds
+ add_links("pthreadVC2-w64")
+ end
target("main_loop")
set_kind("binary")