140 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			CMake
		
	
	
			
		
		
	
	
			140 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			CMake
		
	
	
# Utilities to help with wrapping.
 | 
						|
 | 
						|
# Use CMake's find_package to find the version of Python installed.
 | 
						|
macro(get_python_version)
 | 
						|
  if(${CMAKE_VERSION} VERSION_LESS "3.12.0")
 | 
						|
    # Use older version of cmake's find_python
 | 
						|
    find_package(PythonInterp)
 | 
						|
 | 
						|
    if(NOT ${PYTHONINTERP_FOUND})
 | 
						|
      message(
 | 
						|
        FATAL_ERROR
 | 
						|
          "Cannot find Python interpreter. Please install Python>=3.5.")
 | 
						|
    endif()
 | 
						|
 | 
						|
    find_package(PythonLibs ${PYTHON_VERSION_STRING})
 | 
						|
 | 
						|
  else()
 | 
						|
    # Get info about the Python interpreter
 | 
						|
    # https://cmake.org/cmake/help/latest/module/FindPython.html#module:FindPython
 | 
						|
    find_package(Python COMPONENTS Interpreter Development)
 | 
						|
 | 
						|
    if(NOT ${Python_FOUND})
 | 
						|
      message(
 | 
						|
        FATAL_ERROR
 | 
						|
          "Cannot find Python interpreter. Please install Python>=3.5.")
 | 
						|
    endif()
 | 
						|
 | 
						|
  endif()
 | 
						|
endmacro()
 | 
						|
 | 
						|
# Depending on the version of CMake, ensure all the appropriate variables are set.
 | 
						|
macro(configure_python_variables)
 | 
						|
  if(${CMAKE_VERSION} VERSION_LESS "3.12.0")
 | 
						|
    set(Python_VERSION_MAJOR
 | 
						|
        ${PYTHON_VERSION_MAJOR}
 | 
						|
        CACHE INTERNAL "")
 | 
						|
    set(Python_VERSION_MINOR
 | 
						|
        ${PYTHON_VERSION_MINOR}
 | 
						|
        CACHE INTERNAL "")
 | 
						|
    set(Python_VERSION_PATCH
 | 
						|
        ${PYTHON_VERSION_PATCH}
 | 
						|
        CACHE INTERNAL "")
 | 
						|
    set(Python_EXECUTABLE
 | 
						|
        ${PYTHON_EXECUTABLE}
 | 
						|
        CACHE PATH "")
 | 
						|
 | 
						|
  else()
 | 
						|
    # Set both sets of variables
 | 
						|
    set(PYTHON_VERSION_MAJOR
 | 
						|
        ${Python_VERSION_MAJOR}
 | 
						|
        CACHE INTERNAL "")
 | 
						|
    set(PYTHON_VERSION_MINOR
 | 
						|
        ${Python_VERSION_MINOR}
 | 
						|
        CACHE INTERNAL "")
 | 
						|
    set(PYTHON_VERSION_PATCH
 | 
						|
        ${Python_VERSION_PATCH}
 | 
						|
        CACHE INTERNAL "")
 | 
						|
    set(PYTHON_EXECUTABLE
 | 
						|
        ${Python_EXECUTABLE}
 | 
						|
        CACHE PATH "")
 | 
						|
 | 
						|
  endif()
 | 
						|
endmacro()
 | 
						|
 | 
						|
# Set the Python version for the wrapper and set the paths to the executable and
 | 
						|
# include/library directories.
 | 
						|
# WRAP_PYTHON_VERSION (optionally) can be "Default" or a
 | 
						|
# specific major.minor version.
 | 
						|
macro(gtwrap_get_python_version)
 | 
						|
  # Unset these cached variables to avoid surprises when the python in the
 | 
						|
  # current environment are different from the cached!
 | 
						|
  unset(Python_EXECUTABLE CACHE)
 | 
						|
  unset(Python_INCLUDE_DIRS CACHE)
 | 
						|
  unset(Python_VERSION_MAJOR CACHE)
 | 
						|
  unset(Python_VERSION_MINOR CACHE)
 | 
						|
  unset(Python_VERSION_PATCH CACHE)
 | 
						|
 | 
						|
  # Set default value if the parameter is not passed in
 | 
						|
  if(NOT WRAP_PYTHON_VERSION)
 | 
						|
    set(WRAP_PYTHON_VERSION "Default")
 | 
						|
  endif()
 | 
						|
 | 
						|
  # Allow override
 | 
						|
  if(${WRAP_PYTHON_VERSION} STREQUAL "Default")
 | 
						|
    # Check for Python3 or Python2 in order
 | 
						|
    get_python_version()
 | 
						|
 | 
						|
    # Set the wrapper python version
 | 
						|
    set(WRAP_PYTHON_VERSION
 | 
						|
        "${Python_VERSION_MAJOR}.${Python_VERSION_MINOR}.${Python_VERSION_PATCH}"
 | 
						|
        CACHE STRING "The version of Python to build the wrappers against."
 | 
						|
              FORCE)
 | 
						|
 | 
						|
  else()
 | 
						|
    # Find the Python that best matches the python version specified.
 | 
						|
    find_package(
 | 
						|
      Python ${WRAP_PYTHON_VERSION}
 | 
						|
      COMPONENTS Interpreter Development
 | 
						|
      EXACT)
 | 
						|
  endif()
 | 
						|
 | 
						|
  # (Always) Configure the variables once we find the python package
 | 
						|
  configure_python_variables()
 | 
						|
 | 
						|
endmacro()
 | 
						|
 | 
						|
# Concatenate multiple wrapper interface headers into one.
 | 
						|
# The concatenation will be (re)performed if and only if any interface files
 | 
						|
# change.
 | 
						|
#
 | 
						|
# Arguments:
 | 
						|
# ~~~
 | 
						|
# destination: The concatenated master interface header file will be placed here.
 | 
						|
# inputs (optional): All the input interface header files
 | 
						|
function(combine_interface_headers
 | 
						|
         destination
 | 
						|
         #inputs
 | 
						|
         )
 | 
						|
  # check if any interface headers changed
 | 
						|
  foreach(INTERFACE_FILE ${ARGN})
 | 
						|
    if(NOT EXISTS ${destination} OR
 | 
						|
      ${INTERFACE_FILE} IS_NEWER_THAN ${destination})
 | 
						|
      set(UPDATE_INTERFACE TRUE)
 | 
						|
    endif()
 | 
						|
    # trigger cmake on file change
 | 
						|
    set_property(DIRECTORY
 | 
						|
                 APPEND
 | 
						|
                 PROPERTY CMAKE_CONFIGURE_DEPENDS ${INTERFACE_FILE})
 | 
						|
  endforeach()
 | 
						|
  # if so, then update the overall interface file
 | 
						|
  if (UPDATE_INTERFACE)
 | 
						|
    file(WRITE ${destination} "")
 | 
						|
    # append additional interface headers to end of gtdynamics.i
 | 
						|
    foreach(INTERFACE_FILE ${ARGN})
 | 
						|
      file(READ ${INTERFACE_FILE} interface_contents)
 | 
						|
      file(APPEND ${destination} "${interface_contents}")
 | 
						|
    endforeach()
 | 
						|
  endif()
 | 
						|
endfunction()
 |