mirror of
https://github.com/kunkundi/crossdesk.git
synced 2025-10-26 20:25:34 +08:00
Provide build option 'server_only'
This commit is contained in:
62
xmake.lua
62
xmake.lua
@@ -5,7 +5,10 @@ set_license("LGPL-3.0")
|
||||
add_rules("mode.release", "mode.debug")
|
||||
set_languages("c++17")
|
||||
|
||||
add_rules("mode.release", "mode.debug")
|
||||
|
||||
option("server_only")
|
||||
set_showmenu(true)
|
||||
option_end()
|
||||
|
||||
add_defines("ASIO_STANDALONE", "ASIO_HAS_STD_TYPE_TRAITS", "ASIO_HAS_STD_SHARED_PTR",
|
||||
"ASIO_HAS_STD_ADDRESSOF", "ASIO_HAS_STD_ATOMIC", "ASIO_HAS_STD_CHRONO",
|
||||
@@ -24,73 +27,75 @@ elseif is_os("macosx") then
|
||||
end
|
||||
|
||||
add_requires("asio 1.24.0", "nlohmann_json", "spdlog 1.11.0")
|
||||
add_packages("spdlog")
|
||||
includes("thirdparty")
|
||||
|
||||
if is_os("windows") then
|
||||
if has_config("server_only") then
|
||||
includes("application/signal_server")
|
||||
else
|
||||
if is_os("windows") then
|
||||
add_requires("vcpkg::ffmpeg 5.1.2", {configs = {shared = false}})
|
||||
add_requires("vcpkg::libnice 0.1.21")
|
||||
add_packages("vcpkg::libnice")
|
||||
add_requires("openh264 2.1.1", {configs = {shared = false}})
|
||||
elseif is_os("linux") then
|
||||
elseif is_os("linux") then
|
||||
add_requires("ffmpeg 5.1.2")
|
||||
add_requires("glib", {system = true})
|
||||
add_requires("vcpkg::libnice 0.1.21")
|
||||
add_requires("openh264 2.1.1", {configs = {shared = false}})
|
||||
add_packages("glib", "vcpkg::libnice")
|
||||
elseif is_os("macosx") then
|
||||
elseif is_os("macosx") then
|
||||
add_requires("ffmpeg 5.1.2", {system = false})
|
||||
add_requires("brew::libnice", "brew::glib")
|
||||
add_requires("openh264 2.1.1", {configs = {shared = false}})
|
||||
end
|
||||
end
|
||||
|
||||
add_packages("spdlog")
|
||||
includes("application/remote_desk")
|
||||
includes("application/signal_server")
|
||||
|
||||
includes("thirdparty")
|
||||
includes("application/remote_desk")
|
||||
includes("application/signal_server")
|
||||
|
||||
target("log")
|
||||
target("log")
|
||||
set_kind("headeronly")
|
||||
add_packages("spdlog")
|
||||
add_headerfiles("src/log/log.h")
|
||||
add_includedirs("src/log", {public = true})
|
||||
|
||||
target("common")
|
||||
target("common")
|
||||
set_kind("headeronly")
|
||||
add_includedirs("src/common", {public = true})
|
||||
|
||||
target("inih")
|
||||
target("inih")
|
||||
set_kind("static")
|
||||
add_files("src/inih/ini.c", "src/inih/INIReader.cpp")
|
||||
add_includedirs("src/inih", {public = true})
|
||||
|
||||
target("ringbuffer")
|
||||
target("ringbuffer")
|
||||
set_kind("headeronly")
|
||||
add_includedirs("src/ringbuffer", {public = true})
|
||||
|
||||
target("thread")
|
||||
target("thread")
|
||||
set_kind("static")
|
||||
add_deps("log")
|
||||
add_files("src/thread/*.cpp")
|
||||
add_includedirs("src/thread", {public = true})
|
||||
|
||||
target("frame")
|
||||
target("frame")
|
||||
set_kind("static")
|
||||
add_files("src/frame/*.cpp")
|
||||
add_includedirs("src/frame", {public = true})
|
||||
|
||||
target("rtcp")
|
||||
target("rtcp")
|
||||
set_kind("static")
|
||||
add_deps("log")
|
||||
add_files("src/rtcp/*.cpp")
|
||||
add_includedirs("src/rtcp", {public = true})
|
||||
|
||||
target("rtp")
|
||||
target("rtp")
|
||||
set_kind("static")
|
||||
add_deps("log", "frame", "ringbuffer", "thread", "rtcp")
|
||||
add_files("src/rtp/*.cpp")
|
||||
add_includedirs("src/rtp", {public = true})
|
||||
|
||||
target("ice")
|
||||
target("ice")
|
||||
set_kind("static")
|
||||
add_deps("log", "common", "ws")
|
||||
add_packages("asio", "nlohmann_json")
|
||||
@@ -116,14 +121,14 @@ target("ice")
|
||||
end
|
||||
|
||||
|
||||
target("ws")
|
||||
target("ws")
|
||||
set_kind("static")
|
||||
add_deps("log")
|
||||
add_files("src/ws/*.cpp")
|
||||
add_packages("asio")
|
||||
add_includedirs("thirdparty/websocketpp/include", {public = true})
|
||||
|
||||
target("media")
|
||||
target("media")
|
||||
set_kind("static")
|
||||
add_deps("log", "frame")
|
||||
if is_os("windows") then
|
||||
@@ -182,20 +187,20 @@ target("media")
|
||||
"src/media/video/decode/ffmpeg", {public = true})
|
||||
end
|
||||
|
||||
target("qos")
|
||||
target("qos")
|
||||
set_kind("static")
|
||||
add_deps("log")
|
||||
add_files("src/qos/kcp/*.c")
|
||||
add_includedirs("src/qos/kcp", {public = true})
|
||||
|
||||
target("transmission")
|
||||
target("transmission")
|
||||
set_kind("static")
|
||||
add_deps("log", "ws", "ice", "qos", "rtp", "rtcp")
|
||||
add_files("src/transmission/*.cpp")
|
||||
add_packages("asio", "nlohmann_json")
|
||||
add_includedirs("src/ws", "src/ice", "src/qos", {public = true})
|
||||
|
||||
target("pc")
|
||||
target("pc")
|
||||
set_kind("static")
|
||||
add_deps("log")
|
||||
add_deps("ws", "ice", "transmission", "inih", "common", "media")
|
||||
@@ -204,7 +209,7 @@ target("pc")
|
||||
add_includedirs("src/transmission", "src/interface", {public = true})
|
||||
|
||||
|
||||
target("projectx")
|
||||
target("projectx")
|
||||
set_kind("shared")
|
||||
add_deps("log")
|
||||
add_deps("pc")
|
||||
@@ -215,19 +220,19 @@ target("projectx")
|
||||
-- set_policy("build.merge_archive", true)
|
||||
-- set_targetdir("$(projectdir)/libdrtc/lib")
|
||||
|
||||
target("host")
|
||||
target("host")
|
||||
set_kind("binary")
|
||||
add_deps("projectx")
|
||||
add_files("tests/peerconnection/host.cpp")
|
||||
add_includedirs("src/interface")
|
||||
|
||||
target("guest")
|
||||
target("guest")
|
||||
set_kind("binary")
|
||||
add_deps("projectx")
|
||||
add_files("tests/peerconnection/guest.cpp")
|
||||
add_includedirs("src/interface")
|
||||
|
||||
target("nicetest")
|
||||
target("nicetest")
|
||||
set_kind("binary")
|
||||
add_files("tests/peerconnection/nice.cpp")
|
||||
add_includedirs("E:/SourceCode/vcpkg/installed/x64-windows-static/include/glib-2.0")
|
||||
@@ -237,3 +242,4 @@ target("nicetest")
|
||||
"pcre2-8", "pcre2-16", "pcre2-32", "pcre2-posix",
|
||||
"zlib", "ffi", "libcrypto", "libssl", "intl", "iconv", "charset", "bz2",
|
||||
"Shell32", "Advapi32", "Dnsapi", "Shlwapi", "Iphlpapi")
|
||||
end
|
||||
Reference in New Issue
Block a user