Improve error messages when libraries aren't found
This commit is contained in:
parent
416baf1abe
commit
1e975f64f7
@ -43,7 +43,7 @@ endif(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
|||||||
target_link_libraries(${PROJECT_NAME} PRIVATE pthread curl)
|
target_link_libraries(${PROJECT_NAME} PRIVATE pthread curl)
|
||||||
|
|
||||||
# TODO From Crypto++ 5.7 on, it should support cmake with find_package() instead of find_library().
|
# TODO From Crypto++ 5.7 on, it should support cmake with find_package() instead of find_library().
|
||||||
find_library(CryptoPP cryptopp $ENV{CRYPTOPP_LIB_PATH})
|
find_library_with_path(CryptoPP cryptopp CRYPTOPP_LIB_PATH)
|
||||||
target_link_libraries(${PROJECT_NAME} PUBLIC ${CryptoPP} scrypt spdlog)
|
target_link_libraries(${PROJECT_NAME} PUBLIC ${CryptoPP} scrypt spdlog)
|
||||||
|
|
||||||
target_add_boost(${PROJECT_NAME} filesystem system thread)
|
target_add_boost(${PROJECT_NAME} filesystem system thread)
|
||||||
|
@ -22,9 +22,10 @@ target_activate_cpp14(${PROJECT_NAME})
|
|||||||
|
|
||||||
if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
||||||
set(CMAKE_FIND_FRAMEWORK LAST)
|
set(CMAKE_FIND_FRAMEWORK LAST)
|
||||||
find_library(FUSE osxfuse $ENV{FUSE_LIB_PATH})
|
set(FUSE_LIB_NAME "osxfuse")
|
||||||
else(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
else(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
||||||
find_library(FUSE fuse $ENV{FUSE_LIB_PATH})
|
set(FUSE_LIB_NAME "fuse")
|
||||||
endif(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
endif(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
||||||
|
|
||||||
|
find_library_with_path(FUSE ${FUSE_LIB_NAME} FUSE_LIB_PATH)
|
||||||
target_link_libraries(${PROJECT_NAME} PUBLIC ${FUSE})
|
target_link_libraries(${PROJECT_NAME} PUBLIC ${FUSE})
|
||||||
|
28
utils.cmake
28
utils.cmake
@ -63,7 +63,6 @@ function(require_gcc_version VERSION)
|
|||||||
endif (CMAKE_COMPILER_IS_GNUCXX)
|
endif (CMAKE_COMPILER_IS_GNUCXX)
|
||||||
endfunction(require_gcc_version)
|
endfunction(require_gcc_version)
|
||||||
|
|
||||||
|
|
||||||
##################################################
|
##################################################
|
||||||
# Specify that a specific minimal version of clang is required
|
# Specify that a specific minimal version of clang is required
|
||||||
#
|
#
|
||||||
@ -77,3 +76,30 @@ function(require_clang_version VERSION)
|
|||||||
endif (CMAKE_CXX_COMPILER_VERSION VERSION_LESS ${VERSION})
|
endif (CMAKE_CXX_COMPILER_VERSION VERSION_LESS ${VERSION})
|
||||||
endif(CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
endif(CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
||||||
endfunction(require_clang_version)
|
endfunction(require_clang_version)
|
||||||
|
|
||||||
|
##################################################
|
||||||
|
# Find the location of a library and return its full path in OUTPUT_VARIABLE.
|
||||||
|
# If PATH_VARIABLE points to a defined variable, then the library will only be searched in this path.
|
||||||
|
# If PATH_VARIABLE points to a undefined variable, default system locations will be searched.
|
||||||
|
#
|
||||||
|
# Uses (the following will search for fuse in system locations by default, and if the user passes -DFUSE_LIB_PATH to cmake, it will only search in this path.
|
||||||
|
# find_library_with_path(MYLIBRARY fuse FUSE_LIB_PATH)
|
||||||
|
# target_link_library(target ${MYLIBRARY})
|
||||||
|
##################################################
|
||||||
|
function(find_library_with_path OUTPUT_VARIABLE LIBRARY_NAME PATH_VARIABLE)
|
||||||
|
if(${PATH_VARIABLE})
|
||||||
|
find_library(${OUTPUT_VARIABLE} ${LIBRARY_NAME} PATHS ${${PATH_VARIABLE}} NO_DEFAULT_PATH)
|
||||||
|
if (${OUTPUT_VARIABLE} MATCHES NOTFOUND)
|
||||||
|
message(FATAL_ERROR "Didn't find ${LIBRARY_NAME} in path specified by the ${PATH_VARIABLE} parameter (${${PATH_VARIABLE}}). Pass in the correct path or remove the parameter to try common system locations.")
|
||||||
|
else(${OUTPUT_VARIABLE} MATCHES NOTFOUND)
|
||||||
|
message(STATUS "Found ${LIBRARY_NAME} in user-defined path ${${PATH_VARIABLE}}")
|
||||||
|
endif(${OUTPUT_VARIABLE} MATCHES NOTFOUND)
|
||||||
|
else(${PATH_VARIABLE})
|
||||||
|
find_library(${OUTPUT_VARIABLE} ${LIBRARY_NAME})
|
||||||
|
if (${OUTPUT_VARIABLE} MATCHES NOTFOUND)
|
||||||
|
message(FATAL_ERROR "Didn't find ${LIBRARY_NAME} library. If ${LIBRARY_NAME} is installed, try passing in the library location with -D${PATH_VARIABLE}=/path/to/${LIBRARY_NAME}/lib.")
|
||||||
|
else(${OUTPUT_VARIABLE} MATCHES NOTFOUND)
|
||||||
|
message(STATUS "Found ${LIBRARY_NAME} in system location")
|
||||||
|
endif(${OUTPUT_VARIABLE} MATCHES NOTFOUND)
|
||||||
|
endif(${PATH_VARIABLE})
|
||||||
|
endfunction(find_library_with_path)
|
Loading…
x
Reference in New Issue
Block a user