Try to find Z3 using CONFIG_MODE before manual search.

This commit is contained in:
Daniel Kirchner 2019-06-04 14:55:45 +02:00
parent 95e6b2e40d
commit 9f5340fa53
3 changed files with 43 additions and 23 deletions

View File

@ -11,6 +11,10 @@ Compiler Features:
Bugfixes: Bugfixes:
Build System:
* Attempt to use stock Z3 cmake files to find Z3 and only fall back to manual discovery.
### 0.5.9 (2019-05-28) ### 0.5.9 (2019-05-28)

View File

@ -1,29 +1,45 @@
if (USE_Z3) if (USE_Z3)
find_path(Z3_INCLUDE_DIR NAMES z3++.h PATH_SUFFIXES z3) # Save and clear Z3_FIND_VERSION, since the
find_library(Z3_LIBRARY NAMES z3) # Z3 config module cannot handle version requirements.
find_program(Z3_EXECUTABLE z3 PATH_SUFFIXES bin) set(Z3_FIND_VERSION_ORIG ${Z3_FIND_VERSION})
set(Z3_FIND_VERSION)
if(Z3_INCLUDE_DIR AND Z3_LIBRARY AND Z3_EXECUTABLE) # Try to find Z3 using its stock cmake files.
execute_process (COMMAND ${Z3_EXECUTABLE} -version find_package(Z3 QUIET CONFIG)
OUTPUT_VARIABLE libz3_version_str # Restore Z3_FIND_VERSION for find_package_handle_standard_args.
ERROR_QUIET set(Z3_FIND_VERSION ${Z3_FIND_VERSION_ORIG})
OUTPUT_STRIP_TRAILING_WHITESPACE) set(Z3_FIND_VERSION_ORIG)
string(REGEX REPLACE "^Z3 version ([0-9.]+).*" "\\1"
Z3_VERSION_STRING "${libz3_version_str}")
unset(libz3_version_str)
endif()
mark_as_advanced(Z3_VERSION_STRING z3_DIR)
include(FindPackageHandleStandardArgs) include(FindPackageHandleStandardArgs)
find_package_handle_standard_args(Z3
REQUIRED_VARS Z3_LIBRARY Z3_INCLUDE_DIR
VERSION_VAR Z3_VERSION_STRING)
if (NOT TARGET Z3::Z3) if (Z3_FOUND)
add_library(Z3::Z3 UNKNOWN IMPORTED) set(Z3_VERSION ${Z3_VERSION_STRING})
set_property(TARGET Z3::Z3 PROPERTY IMPORTED_LOCATION ${Z3_LIBRARY}) find_package_handle_standard_args(Z3 CONFIG_MODE)
set_property(TARGET Z3::Z3 PROPERTY INTERFACE_INCLUDE_DIRECTORIES ${Z3_INCLUDE_DIR}) else()
find_path(Z3_INCLUDE_DIR NAMES z3++.h PATH_SUFFIXES z3)
find_library(Z3_LIBRARY NAMES z3)
find_program(Z3_EXECUTABLE z3 PATH_SUFFIXES bin)
if(Z3_INCLUDE_DIR AND Z3_LIBRARY AND Z3_EXECUTABLE)
execute_process (COMMAND ${Z3_EXECUTABLE} -version
OUTPUT_VARIABLE libz3_version_str
ERROR_QUIET
OUTPUT_STRIP_TRAILING_WHITESPACE)
string(REGEX REPLACE "^Z3 version ([0-9.]+).*" "\\1"
Z3_VERSION_STRING "${libz3_version_str}")
unset(libz3_version_str)
endif()
mark_as_advanced(Z3_VERSION_STRING z3_DIR)
find_package_handle_standard_args(Z3
REQUIRED_VARS Z3_LIBRARY Z3_INCLUDE_DIR
VERSION_VAR Z3_VERSION_STRING)
if (NOT TARGET z3::libz3)
add_library(z3::libz3 UNKNOWN IMPORTED)
set_property(TARGET z3::libz3 PROPERTY IMPORTED_LOCATION ${Z3_LIBRARY})
set_property(TARGET z3::libz3 PROPERTY INTERFACE_INCLUDE_DIRECTORIES ${Z3_INCLUDE_DIR})
endif()
endif() endif()
else() else()
set(Z3_FOUND FALSE) set(Z3_FOUND FALSE)

View File

@ -140,7 +140,7 @@ add_library(solidity ${sources} ${z3_SRCS} ${cvc4_SRCS})
target_link_libraries(solidity PUBLIC yul evmasm langutil devcore ${Boost_FILESYSTEM_LIBRARY} ${Boost_SYSTEM_LIBRARY}) target_link_libraries(solidity PUBLIC yul evmasm langutil devcore ${Boost_FILESYSTEM_LIBRARY} ${Boost_SYSTEM_LIBRARY})
if (${Z3_FOUND}) if (${Z3_FOUND})
target_link_libraries(solidity PUBLIC Z3::Z3) target_link_libraries(solidity PUBLIC z3::libz3)
endif() endif()
if (${CVC4_FOUND}) if (${CVC4_FOUND})