summaryrefslogtreecommitdiff
path: root/cmake
diff options
context:
space:
mode:
authorGuy Harris <guy@alum.mit.edu>2018-01-26 20:02:18 -0800
committerGuy Harris <guy@alum.mit.edu>2018-01-26 20:02:32 -0800
commit253ef5db8200459767800f1f653871664ec2a1ea (patch)
tree497ec95a09f3b73c41169a224f3062b23a334ae6 /cmake
parent944e93fa4c29c4e5cdecd858ead5a37430a418af (diff)
downloadtcpdump-253ef5db8200459767800f1f653871664ec2a1ea.tar.gz
Don't do "here's the directories in which to look for libraries".
CMake *hates* that. -L considered harmful, I guess (and I don't know how that's done with tools other than UN*X linkers - do all of them support an equivalent to -L?). This should fix the checks for pcap functions to look in the library we found.
Diffstat (limited to 'cmake')
-rw-r--r--cmake/Modules/FindPCAP.cmake56
1 files changed, 35 insertions, 21 deletions
diff --git a/cmake/Modules/FindPCAP.cmake b/cmake/Modules/FindPCAP.cmake
index bc17f7ab..af705265 100644
--- a/cmake/Modules/FindPCAP.cmake
+++ b/cmake/Modules/FindPCAP.cmake
@@ -16,7 +16,7 @@ if(PCAP_CONFIG)
endif()
string(REGEX REPLACE "-I" "" PCAP_INCLUDE_DIR ${PCAP_CONFIG_OUTPUT})
- # Now, get the library directories and libraries.
+ # Now, get the libraries.
execute_process(COMMAND "${PCAP_CONFIG}" "--libs"
RESULT_VARIABLE PCAP_CONFIG_RESULT
OUTPUT_VARIABLE PCAP_CONFIG_OUTPUT
@@ -26,16 +26,24 @@ if(PCAP_CONFIG)
message(FATAL_ERROR "pcap-config --libs failed")
endif()
separate_arguments(LIBS_LIST UNIX_COMMAND ${PCAP_CONFIG_OUTPUT})
- set(PCAP_LIBRARY_DIRS)
+ set(_pcap_library_dirs)
set(PCAP_LIBRARIES)
- foreach(arg IN LISTS LIBS_LIST)
- if(arg MATCHES "^-L")
- # Add this directory to PCAP_LIBRARY_DIRS
- string(REGEX REPLACE "-L" "" dir ${arg})
- list(APPEND PCAP_LIBRARY_DIRS ${dir})
- elseif(arg MATCHES "^-l")
- string(REGEX REPLACE "-l" "" lib ${arg})
- list(APPEND PCAP_LIBRARIES ${lib})
+ foreach(_arg IN LISTS LIBS_LIST)
+ if(_arg MATCHES "^-L")
+ # Add this directory to _pcap_library_dirs
+ string(REGEX REPLACE "-L" "" _dir ${_arg})
+ list(APPEND _pcap_library_dirs ${_dir})
+ elseif(_arg MATCHES "^-l")
+ string(REGEX REPLACE "-l" "" _lib ${_arg})
+ #
+ # Try to find that library, so we get its full path.
+ # CMake *really* doesn't like the notion of specifying "here are
+ # the directories in which to look for libraries" except in
+ # find_library() calls; it *really* prefers using full paths to
+ # library files, rather than library names.
+ #
+ find_library(_libfullpath ${_lib} HINTS ${__pcap_library_dirs})
+ list(APPEND PCAP_LIBRARIES ${_libfullpath})
endif()
endforeach()
@@ -48,16 +56,21 @@ if(PCAP_CONFIG)
message(FATAL_ERROR "pcap-config --libs --static failed")
endif()
separate_arguments(LIBS_LIST UNIX_COMMAND ${PCAP_CONFIG_OUTPUT})
- set(PCAP_STATIC_LIBRARY_DIRS)
+ set(_pcap_static_library_dirs)
set(PCAP_STATIC_LIBRARIES)
- foreach(arg IN LISTS LIBS_LIST)
- if(arg MATCHES "^-L")
- # Add this directory to PCAP_STATIC_LIBRARY_DIRS
- string(REGEX REPLACE "-L" "" dir ${arg})
- list(APPEND PCAP_STATIC_LIBRARY_DIRS ${dir})
- elseif(flag MATCHES "^-l")
- string(REGEX REPLACE "-l" "" lib ${arg})
- list(APPEND PCAP_STATIC_LIBRARIES ${lib})
+ foreach(_arg IN LISTS LIBS_LIST)
+ if(_arg MATCHES "^-L")
+ # Add this directory to _pcap_static_library_dirs
+ string(REGEX REPLACE "-L" "" _dir ${_arg})
+ list(APPEND _pcap_static_library_dirs ${_dir})
+ elseif(_arg MATCHES "^-l")
+ string(REGEX REPLACE "-l" "" _lib ${_arg})
+ #
+ # Try to find that library, so we get its full path, as
+ # we do with dynamic libraries.
+ #
+ find_library(_libfullpath ${_lib} HINTS ${__pcap_static_library_dirs})
+ list(APPEND PCAP_STATIC_LIBRARIES ${_libfullpath})
endif()
endforeach()
@@ -65,13 +78,13 @@ if(PCAP_CONFIG)
find_path(PCAP_INCLUDE_DIR pcap.h HINTS ${PCAP_INCLUDE_DIRS})
# Try to find the library
- find_library(PCAP_LIBRARY pcap HINTS ${PCAP_LIBRARY_DIRS})
+ find_library(PCAP_LIBRARY pcap HINTS ${_pcap_library_dirs})
# Try to find the static library (XXX - what about AIX?)
include(CMakePushCheckState)
cmake_push_check_state()
set(CMAKE_FIND_LIBRARY_SUFFIXES ".a")
- find_library(PCAP_STATIC_LIBRARY pcap HINTS ${PCAP_STATIC_LIBRARY_DIRS})
+ find_library(PCAP_STATIC_LIBRARY pcap HINTS ${_pcap_static_library_dirs})
cmake_pop_check_state()
else(PCAP_CONFIG)
# Try to find the header
@@ -89,6 +102,7 @@ else(PCAP_CONFIG)
set(PCAP_INCLUDE_DIRS ${PCAP_INCLUDE_DIR})
set(PCAP_LIBRARIES ${PCAP_LIBRARY})
+ set(PCAP_STATIC_LIBRARIES ${PCAP_STATIC_LIBRARY})
endif(PCAP_CONFIG)
include(FindPackageHandleStandardArgs)