mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-21 23:21:59 +00:00
Drop libnsl dependency (because of gRPC -> c-ares)
c-ares searching for gethostbyname in the libnsl library, however in the version that shipped with gRPC it doing it wrong [1], since it uses CHECK_LIBRARY_EXISTS(), which will return TRUE even if the function exists in another dependent library. The upstream already contains correct macro [2], but it is not included in gRPC (even upstream gRPC, not the one that is shipped with clickhousee). [1]:e982924ace/CMakeLists.txt (L125)
[2]:44fbc81368/CMakeLists.txt (L146)
And because if you by some reason have libnsl [3] installed, clickhouse will reject to start w/o it. While this is completelly different library. [3]: https://packages.debian.org/bullseye/libnsl2
This commit is contained in:
parent
424df030af
commit
5fc2c2169a
@ -54,6 +54,26 @@ else ()
|
|||||||
set(CARES_SHARED ON CACHE BOOL "" FORCE)
|
set(CARES_SHARED ON CACHE BOOL "" FORCE)
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
|
# Disable looking for libnsl on a platforms that has gethostbyname in glibc
|
||||||
|
#
|
||||||
|
# c-ares searching for gethostbyname in the libnsl library, however in the
|
||||||
|
# version that shipped with gRPC it doing it wrong [1], since it uses
|
||||||
|
# CHECK_LIBRARY_EXISTS(), which will return TRUE even if the function exists in
|
||||||
|
# another dependent library. The upstream already contains correct macro [2],
|
||||||
|
# but it is not included in gRPC (even upstream gRPC, not the one that is
|
||||||
|
# shipped with clickhousee).
|
||||||
|
#
|
||||||
|
# [1]: https://github.com/c-ares/c-ares/blob/e982924acee7f7313b4baa4ee5ec000c5e373c30/CMakeLists.txt#L125
|
||||||
|
# [2]: https://github.com/c-ares/c-ares/blob/44fbc813685a1fa8aa3f27fcd7544faf612d376a/CMakeLists.txt#L146
|
||||||
|
#
|
||||||
|
# And because if you by some reason have libnsl [3] installed, clickhouse will
|
||||||
|
# reject to start w/o it. While this is completelly different library.
|
||||||
|
#
|
||||||
|
# [3]: https://packages.debian.org/bullseye/libnsl2
|
||||||
|
if (NOT CMAKE_SYSTEM_NAME STREQUAL "SunOS")
|
||||||
|
set(HAVE_LIBNSL OFF CACHE BOOL "" FORCE)
|
||||||
|
endif()
|
||||||
|
|
||||||
# We don't want to build C# extensions.
|
# We don't want to build C# extensions.
|
||||||
set(gRPC_BUILD_CSHARP_EXT OFF)
|
set(gRPC_BUILD_CSHARP_EXT OFF)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user