[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [37619] trunk/blender/build_files/cmake/ FindPythonLibsUnix.cmake: make better use of cmake builtin funcitons for finding python library/ header
Campbell Barton
ideasman42 at gmail.com
Sat Jun 18 17:15:31 CEST 2011
Revision: 37619
http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=37619
Author: campbellbarton
Date: 2011-06-18 15:15:31 +0000 (Sat, 18 Jun 2011)
Log Message:
-----------
make better use of cmake builtin funcitons for finding python library/header
Modified Paths:
--------------
trunk/blender/build_files/cmake/FindPythonLibsUnix.cmake
Modified: trunk/blender/build_files/cmake/FindPythonLibsUnix.cmake
===================================================================
--- trunk/blender/build_files/cmake/FindPythonLibsUnix.cmake 2011-06-18 14:12:54 UTC (rev 37618)
+++ trunk/blender/build_files/cmake/FindPythonLibsUnix.cmake 2011-06-18 15:15:31 UTC (rev 37619)
@@ -5,21 +5,30 @@
# PYTHON_LIBRARY
# PYTHON_LIBPATH
# PYTHON_LINKFLAGS
+# PYTHON_ROOT_DIR, The base directory to search for Python.
+# This can also be an environment variable.
#=============================================================================
+# If PYTHON_ROOT_DIR was defined in the environment, use it.
+IF(NOT PYTHON_ROOT_DIR AND NOT $ENV{PYTHON_ROOT_DIR} STREQUAL "")
+ SET(PYTHON_ROOT_DIR $ENV{PYTHON_ROOT_DIR})
+ENDIF()
+
+
set(PYTHON_VERSION 3.2 CACHE STRING "")
mark_as_advanced(PYTHON_VERSION)
set(PYTHON_LINKFLAGS "-Xlinker -export-dynamic")
mark_as_advanced(PYTHON_LINKFLAGS)
-set(_Python_ABI_FLAGS
+set(_python_ABI_FLAGS
"m;mu;u; ")
string(REPLACE "." "" _PYTHON_VERSION_NO_DOTS ${PYTHON_VERSION})
-set(_Python_PATHS
+set(_python_SEARCH_DIRS
+ ${PYTHON_ROOT_DIR}
"$ENV{HOME}/py${_PYTHON_VERSION_NO_DOTS}"
"/opt/py${_PYTHON_VERSION_NO_DOTS}"
"/usr"
@@ -31,54 +40,59 @@
NOT DEFINED PYTHON_LIBPATH)
message(STATUS "Looking for include Python.h")
- set(_Found_PYTHON_H OFF)
- foreach(_CURRENT_PATH ${_Python_PATHS})
- foreach(_CURRENT_ABI_FLAGS ${_Python_ABI_FLAGS})
- if(CMAKE_BUILD_TYPE STREQUAL Debug)
- set(_CURRENT_ABI_FLAGS "d${_CURRENT_ABI_FLAGS}")
- endif()
- string(REPLACE " " "" _CURRENT_ABI_FLAGS ${_CURRENT_ABI_FLAGS})
+ foreach(_CURRENT_ABI_FLAGS ${_python_ABI_FLAGS})
+ if(CMAKE_BUILD_TYPE STREQUAL Debug)
+ set(_CURRENT_ABI_FLAGS "d${_CURRENT_ABI_FLAGS}")
+ endif()
+ string(REPLACE " " "" _CURRENT_ABI_FLAGS ${_CURRENT_ABI_FLAGS})
- set(_Python_HEADER "${_CURRENT_PATH}/include/python${PYTHON_VERSION}${_CURRENT_ABI_FLAGS}/Python.h")
+ find_path(PYTHON_INCLUDE_DIR
+ NAMES Python.h
+ HINTS ${_python_SEARCH_DIRS}
+ PATH_SUFFIXES include/python${PYTHON_VERSION}${_CURRENT_ABI_FLAGS}
+ )
- if(EXISTS ${_Python_HEADER})
- message(STATUS "Checking for header: ${_Python_HEADER} - found")
- set(_Found_PYTHON_H ON)
- set(PYTHON ${_CURRENT_PATH})
- set(PYTHON_ABI_FLAGS ${_CURRENT_ABI_FLAGS})
- break()
- else()
- message(STATUS "Checking for header: ${_Python_HEADER}")
- endif()
- endforeach()
-
- if(_Found_PYTHON_H)
+ find_library(PYTHON_LIBRARY
+ NAMES "python${PYTHON_VERSION}${_CURRENT_ABI_FLAGS}"
+ HINTS ${_python_SEARCH_DIRS}
+ PATH_SUFFIXES lib64 lib
+ )
+
+ if((EXISTS ${PYTHON_LIBRARY}) AND (EXISTS ${PYTHON_INCLUDE_DIR}))
+ message(STATUS "Checking for header: ${PYTHON_INCLUDE_DIR} - found")
break()
+ else()
+ message(STATUS "Checking for header: ${PYTHON_INCLUDE_DIR}")
endif()
+
+ # ensure we dont find values from 2 different ABI versions
+ unset(PYTHON_INCLUDE_DIR CACHE)
+ unset(PYTHON_LIBRARY CACHE)
endforeach()
- if(NOT _Found_PYTHON_H)
- message(FATAL_ERROR "Python.h not found")
+ if((EXISTS ${PYTHON_LIBRARY}) AND (EXISTS ${PYTHON_INCLUDE_DIR}))
+ # Assign cache items
+ set(PYTHON_INCLUDE_DIRS ${PYTHON_INCLUDE_DIR} CACHE STRING "")
+ set(PYTHON_LIBRARY ${PYTHON_LIBRARY} CACHE STRING "")
+ # not used
+ # set(PYTHON_BINARY ${PYTHON_EXECUTABLE} CACHE STRING "")
+
+ mark_as_advanced(
+ PYTHON_INCLUDE_DIRS
+ PYTHON_INCLUDE_DIR
+ PYTHON_LIBRARY
+ )
+ else()
+ message(FATAL_ERROR "Python not found")
endif()
- unset(_Found_PYTHON_H)
- unset(_Python_HEADER)
unset(_CURRENT_ABI_FLAGS)
unset(_CURRENT_PATH)
-
-
- set(PYTHON_INCLUDE_DIRS "${PYTHON}/include/python${PYTHON_VERSION}${PYTHON_ABI_FLAGS}" CACHE STRING "")
- mark_as_advanced(PYTHON_INCLUDE_DIRS)
- set(PYTHON_LIBRARY "python${PYTHON_VERSION}${PYTHON_ABI_FLAGS}" CACHE STRING "")
- mark_as_advanced(PYTHON_LIBRARY)
- set(PYTHON_LIBPATH ${PYTHON}/lib CACHE STRING "")
- mark_as_advanced(PYTHON_LIBPATH)
- # set(PYTHON_BINARY ${PYTHON_EXECUTABLE} CACHE STRING "")
endif()
-unset(_Python_ABI_FLAGS)
-unset(_Python_PATHS)
+unset(_python_ABI_FLAGS)
+unset(_python_SEARCH_DIRS)
#=============================================================================
# now the python versions are found
More information about the Bf-blender-cvs
mailing list