[Lldb-commits] [lldb] r226679 - Some fixes for linking Python on Windows.

Zachary Turner zturner at google.com
Wed Jan 21 09:53:10 PST 2015


Author: zturner
Date: Wed Jan 21 11:53:10 2015
New Revision: 226679

URL: http://llvm.org/viewvc/llvm-project?rev=226679&view=rev
Log:
Some fixes for linking Python on Windows.

CMake FindPythonLibs will look for multiple versions of Python
including both debug and release, and build up a list such as
(debug <debugpath> optimized <optimizedpath>).  This confuses
the logic we have in CMake to copy the correct python dll to
the output directory so that it need not be in your system's PATH.

To alleviate this, we manually split this list and extract out
the debug and release versions of the python library, and copy
only the correct one to the output directory.

Modified:
    lldb/trunk/CMakeLists.txt
    lldb/trunk/scripts/CMakeLists.txt

Modified: lldb/trunk/CMakeLists.txt
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/CMakeLists.txt?rev=226679&r1=226678&r2=226679&view=diff
==============================================================================
--- lldb/trunk/CMakeLists.txt (original)
+++ lldb/trunk/CMakeLists.txt Wed Jan 21 11:53:10 2015
@@ -137,6 +137,23 @@ if (NOT LLDB_DISABLE_PYTHON)
     endif()
   endif()
   find_package(PythonLibs REQUIRED)
+  # PYTHON_LIBRARIES is now a list in the form (debug DebugPath optimized OptimizedPath)
+  # So we need to parse it to get the path to the respective installations.
+  list(FIND PYTHON_LIBRARIES optimized PYTHON_OPTIMIZED_INDEX)
+  list(FIND PYTHON_LIBRARIES debug PYTHON_DEBUG_INDEX)
+  if (NOT ${PYTHON_OPTIMIZED_INDEX} EQUAL -1)
+    MATH(EXPR PYTHON_OPTIMIZED_INDEX "${PYTHON_OPTIMIZED_INDEX}+1")
+    list(GET PYTHON_LIBRARIES ${PYTHON_OPTIMIZED_INDEX} PYTHON_RELEASE_LIBRARY)
+  endif()
+  if (NOT ${PYTHON_DEBUG_INDEX} EQUAL -1)
+    MATH(EXPR PYTHON_DEBUG_INDEX "${PYTHON_DEBUG_INDEX}+1")
+    list(GET PYTHON_LIBRARIES ${PYTHON_DEBUG_INDEX} PYTHON_DEBUG_LIBRARY)
+  endif()
+  if (CMAKE_BUILD_TYPE STREQUAL "Debug")
+    set(PYTHON_LIBRARY ${PYTHON_DEBUG_LIBRARY})
+  else()
+    set(PYTHON_LIBRARY ${PYTHON_RELEASE_LIBRARY})
+  endif()
   include_directories(${PYTHON_INCLUDE_DIRS})
 endif()
 

Modified: lldb/trunk/scripts/CMakeLists.txt
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/scripts/CMakeLists.txt?rev=226679&r1=226678&r2=226679&view=diff
==============================================================================
--- lldb/trunk/scripts/CMakeLists.txt (original)
+++ lldb/trunk/scripts/CMakeLists.txt Wed Jan 21 11:53:10 2015
@@ -3,7 +3,8 @@ set(LLVM_NO_RTTI 1)
 file(GLOB SWIG_INPUTS Python/interface/*.i)
 
 if (CMAKE_SYSTEM_NAME MATCHES "Windows")
-    STRING(REGEX REPLACE ".lib" ".dll" PYTHON_DLL ${PYTHON_LIBRARY})
+    STRING(REGEX REPLACE "[.]lib" ".dll" PYTHON_DLL ${PYTHON_LIBRARY})
+    message("Copying ${PYTHON_DLL} to ${CMAKE_BINARY_DIR}/bin")
     file(COPY ${PYTHON_DLL} DESTINATION ${CMAKE_BINARY_DIR}/bin)
 endif ()
 





More information about the lldb-commits mailing list