aboutsummaryrefslogtreecommitdiff
path: root/cmake/FindLpeg.cmake
diff options
context:
space:
mode:
Diffstat (limited to 'cmake/FindLpeg.cmake')
-rw-r--r--cmake/FindLpeg.cmake11
1 files changed, 10 insertions, 1 deletions
diff --git a/cmake/FindLpeg.cmake b/cmake/FindLpeg.cmake
index 3d0ff5929d..7657bdac9e 100644
--- a/cmake/FindLpeg.cmake
+++ b/cmake/FindLpeg.cmake
@@ -1,4 +1,13 @@
-find_library2(LPEG_LIBRARY NAMES lpeg_a lpeg liblpeg_a lpeg${CMAKE_SHARED_LIBRARY_SUFFIX} PATH_SUFFIXES lua/5.1)
+find_library2(LPEG_LIBRARY NAMES lpeg_a lpeg liblpeg_a lpeg.so lpeg${CMAKE_SHARED_LIBRARY_SUFFIX} PATH_SUFFIXES lua/5.1)
+if(CMAKE_SYSTEM_NAME STREQUAL "Darwin" AND LPEG_LIBRARY MATCHES ".so$")
+ execute_process(
+ COMMAND otool -hv "${LPEG_LIBRARY}"
+ OUTPUT_VARIABLE LPEG_HEADER
+ )
+ if(LPEG_HEADER MATCHES ".* BUNDLE .*")
+ message(FATAL_ERROR "lpeg library found at ${LPEG_LIBRARY} but built as a bundle rather than a dylib, please rebuild with `-dynamiclib` rather than `-bundle`")
+ endif()
+endif()
find_package_handle_standard_args(Lpeg DEFAULT_MSG LPEG_LIBRARY)
mark_as_advanced(LPEG_LIBRARY)