Browse Source

librdkafka: version 1.8.2-POST2, fix static lib build. (#1028)

* librdkafka: version 1.8.2-POST2, fix static lib build.

* Update xmake.lua

Co-authored-by: ruki <[email protected]>
Chen Yufei 3 years ago
parent
commit
c8e57d5c73
1 changed files with 40 additions and 6 deletions
  1. 40 6
      packages/l/librdkafka/xmake.lua

+ 40 - 6
packages/l/librdkafka/xmake.lua

@@ -5,24 +5,58 @@ package("librdkafka")
     add_urls("https://github.com/edenhill/librdkafka/archive/refs/tags/$(version).tar.gz",
     add_urls("https://github.com/edenhill/librdkafka/archive/refs/tags/$(version).tar.gz",
              "https://github.com/edenhill/librdkafka.git")
              "https://github.com/edenhill/librdkafka.git")
     add_versions("v1.6.2", "b9be26c632265a7db2fdd5ab439f2583d14be08ab44dc2e33138323af60c39db")
     add_versions("v1.6.2", "b9be26c632265a7db2fdd5ab439f2583d14be08ab44dc2e33138323af60c39db")
+    add_versions("v1.8.2-POST2", "d556d07cb88ea689e28c8e058ec3265ab333c9fc5e8f4ac0b7509bb5ae0e9f25")
 
 
-    add_configs("ssl", { description = "Enable ssl.", default = false, type = "boolean"})
+    if is_plat("windows", "mingw") then
+        -- Do not build static library for window.
+        add_configs("shared", {description = "Build shared library.", default = true, type = "boolean", readonly = true})
+        add_configs("vs_runtime", {description = "Set vs compiler runtime.", default = "MD", readonly = true})
+    end
+
+    -- lz4_ext means using external lz4 library instead of librdkafka's bundled one.
+    -- When lz4_ext is disabled, we still need to link with external lz4 library.
+    local config_default = {lz4_ext = true}
+    local configdeps = {lz4_ext = "lz4", sasl = "cyrus-sasl", ssl = "openssl", zlib = "zlib", zstd = "std"}
+    for config, dep in pairs(configdeps) do
+        add_configs(config, {description = "Enable " .. config .. " support.", default = config_default[config] or false, type = "boolean"})
+    end
 
 
     add_deps("cmake")
     add_deps("cmake")
 
 
     add_links("rdkafka++", "rdkafka")
     add_links("rdkafka++", "rdkafka")
 
 
+    -- These syslinks come from PKG_CONFIG_LIBS_PRIVATE in librdkafka/src/CMakeLists.txt
+    if is_plat("linux") or is_plat("bsd") then
+        add_syslinks("pthread", "dl")
+    elseif is_plat("mingw", "windows") then
+        add_syslinks("ws2_32", "secur32", "crypt32")
+    end
+
     on_load(function (package)
     on_load(function (package)
-        if package:config("ssl") then
-            package:add("deps", "openssl")
+        for name, dep in pairs(configdeps) do
+            if package:config(name) then
+                package:add("deps", dep)
+                if name == "sasl" then
+                    package:add("syslinks", "sasl2")
+                else
+                    package:add("syslinks", dep)
+                end
+            end
         end
         end
     end)
     end)
 
 
-    on_install("linux", "macosx", "windows", "cross", function (package)
-        local configs = {"-DRDKAFKA_BUILD_EXAMPLES=OFF", "-DRDKAFKA_BUILD_TESTS=OFF"}
+    on_install(function (package)
+        local configs = {
+            "-DRDKAFKA_BUILD_EXAMPLES=OFF",
+            "-DRDKAFKA_BUILD_TESTS=OFF",
+            "-DWITH_BUNDLED_SSL=OFF",
+        }
         table.insert(configs, "-DWITH_SSL=" .. (package:config("ssl") and "ON" or "OFF"))
         table.insert(configs, "-DWITH_SSL=" .. (package:config("ssl") and "ON" or "OFF"))
         table.insert(configs, "-DCMAKE_BUILD_TYPE=" .. (package:debug() and "Debug" or "Release"))
         table.insert(configs, "-DCMAKE_BUILD_TYPE=" .. (package:debug() and "Debug" or "Release"))
-        table.insert(configs, "-DBUILD_SHARED_LIBS=" .. (package:config("shared") and "ON" or "OFF"))
+        table.insert(configs, "-DRDKAFKA_BUILD_STATIC=" .. (package:config("shared") and "OFF" or "ON"))
+        for config, dep in pairs(configdeps) do
+            table.insert(configs, "-DWITH_" .. config:upper()  .. "=" .. (package:config(config) and "ON" or "OFF"))
+        end
         import("package.tools.cmake").install(package, configs)
         import("package.tools.cmake").install(package, configs)
     end)
     end)