summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTim D. Smith <git@tim-smith.us>2015-05-04 14:55:14 -0700
committerTim D. Smith <git@tim-smith.us>2015-05-04 14:55:14 -0700
commit5f08e2786d483eccdc2760451f0fbdb52727ccf1 (patch)
tree7d5f1bfb6ae19b00fb53f176cb77c1f398ceb185
parent61156c861818642fb624932af3c7c7b63b14a5b3 (diff)
downloadfork-ledger-5f08e2786d483eccdc2760451f0fbdb52727ccf1.tar.gz
fork-ledger-5f08e2786d483eccdc2760451f0fbdb52727ccf1.tar.bz2
fork-ledger-5f08e2786d483eccdc2760451f0fbdb52727ccf1.zip
Don't explicitly link libpython on OS X
Use -undefined dynamic_lookup to allow Python symbols to be discovered when the ledger module is imported instead of at build time. Without this change, the Python interpreter crashes when ledger is imported from a python that is different from (but compatible with) the python against which the module was built.
-rw-r--r--CMakeLists.txt9
1 files changed, 8 insertions, 1 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index da075cde..6166780c 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -225,7 +225,14 @@ macro(add_ledger_library_dependencies _target)
target_link_libraries(${_target} ${INTL_LIB})
endif()
if (HAVE_BOOST_PYTHON)
- target_link_libraries(${_target} ${Boost_LIBRARIES} ${PYTHON_LIBRARIES})
+ if(APPLE)
+ # Don't link directly to a Python framework on OS X, to avoid segfaults
+ # when the module is imported from a different interpreter
+ target_link_libraries(${_target} ${Boost_LIBRARIES})
+ set_target_properties(${_target} PROPERTIES LINK_FLAGS "-undefined dynamic_lookup")
+ else()
+ target_link_libraries(${_target} ${Boost_LIBRARIES} ${PYTHON_LIBRARIES})
+ endif()
else()
target_link_libraries(${_target} ${Boost_LIBRARIES})
endif()