|
6 | 6 | # |
7 | 7 | # Copyright (c) 2008-2014 OpenShot Studios, LLC |
8 | 8 | # <http://www.openshotstudios.com/>. This file is part of |
9 | | -# OpenShot Library (libopenshot), an open-source project dedicated to |
10 | | -# delivering high quality video editing and animation solutions to the |
| 9 | +# OpenShot Library (libopenshot), an open-source project dedicated to |
| 10 | +# delivering high quality video editing and animation solutions to the |
11 | 11 | # world. For more information visit <http://www.openshot.org/>. |
12 | 12 | # |
13 | 13 | # OpenShot Library (libopenshot) is free software: you can redistribute it |
|
29 | 29 | FIND_PACKAGE(SWIG 2.0 REQUIRED) |
30 | 30 | INCLUDE(${SWIG_USE_FILE}) |
31 | 31 |
|
| 32 | +### Enable some legacy SWIG behaviors, in newer CMAKEs |
| 33 | +if (CMAKE_VERSION VERSION_GREATER 3.13) |
| 34 | + cmake_policy(SET CMP0078 OLD) |
| 35 | +endif() |
| 36 | +if (CMAKE_VERSION VERSION_GREATER 3.14) |
| 37 | + cmake_policy(SET CMP0086 OLD) |
| 38 | +endif() |
| 39 | + |
32 | 40 | FIND_PACKAGE(PythonLibs 3) |
33 | 41 | FIND_PACKAGE(PythonInterp 3) |
34 | | -IF (PYTHONLIBS_FOUND) |
35 | | - IF (PYTHONINTERP_FOUND) |
| 42 | +if (PYTHONLIBS_FOUND AND PYTHONINTERP_FOUND) |
| 43 | + |
| 44 | + ### Include Python header files |
| 45 | + INCLUDE_DIRECTORIES(${PYTHON_INCLUDE_PATH}) |
| 46 | + INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}) |
| 47 | + |
| 48 | + ### Enable C++ support in SWIG |
| 49 | + set_property(SOURCE openshot.i PROPERTY CPLUSPLUS ON) |
| 50 | + set_property(SOURCE openshot.i PROPERTY SWIG_MODULE_NAME openshot) |
| 51 | + SET(CMAKE_SWIG_FLAGS "") |
| 52 | + |
| 53 | + ### Add the SWIG interface file (which defines all the SWIG methods) |
| 54 | + if (CMAKE_VERSION VERSION_LESS 3.8.0) |
| 55 | + swig_add_module(pyopenshot python openshot.i) |
| 56 | + else() |
| 57 | + swig_add_library(pyopenshot LANGUAGE python SOURCES openshot.i) |
| 58 | + endif() |
| 59 | + |
| 60 | + ### Set output name of target |
| 61 | + set_target_properties(${SWIG_MODULE_pyopenshot_REAL_NAME} PROPERTIES |
| 62 | + PREFIX "_" OUTPUT_NAME "openshot") |
36 | 63 |
|
37 | | - ### Include Python header files |
38 | | - INCLUDE_DIRECTORIES(${PYTHON_INCLUDE_PATH}) |
39 | | - INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}) |
40 | | - |
41 | | - ### Enable C++ support in SWIG |
42 | | - SET_SOURCE_FILES_PROPERTIES(openshot.i PROPERTIES CPLUSPLUS ON) |
43 | | - SET(CMAKE_SWIG_FLAGS "") |
44 | | - |
45 | | - ### Add the SWIG interface file (which defines all the SWIG methods) |
46 | | - SWIG_ADD_MODULE(openshot python openshot.i) |
| 64 | + ### Link the new python wrapper library with libopenshot |
| 65 | + target_link_libraries(${SWIG_MODULE_pyopenshot_REAL_NAME} |
| 66 | + ${PYTHON_LIBRARIES} openshot) |
47 | 67 |
|
48 | | - ### Link the new python wrapper library with libopenshot |
49 | | - SWIG_LINK_LIBRARIES(openshot ${PYTHON_LIBRARIES} openshot) |
| 68 | + ### FIND THE PYTHON INTERPRETER (AND THE SITE PACKAGES FOLDER) |
| 69 | + execute_process ( COMMAND ${PYTHON_EXECUTABLE} -c "\ |
| 70 | +from distutils.sysconfig import get_python_lib; \ |
| 71 | +print( get_python_lib( plat_specific=True, prefix='${CMAKE_INSTALL_PREFIX}' ) )" |
| 72 | + OUTPUT_VARIABLE _ABS_PYTHON_MODULE_PATH |
| 73 | + OUTPUT_STRIP_TRAILING_WHITESPACE ) |
50 | 74 |
|
51 | | - ### FIND THE PYTHON INTERPRETER (AND THE SITE PACKAGES FOLDER) |
52 | | - EXECUTE_PROCESS ( COMMAND ${PYTHON_EXECUTABLE} -c "import site; print(site.getsitepackages()[0])" |
53 | | - OUTPUT_VARIABLE _ABS_PYTHON_MODULE_PATH |
54 | | - OUTPUT_STRIP_TRAILING_WHITESPACE ) |
55 | | - GET_FILENAME_COMPONENT(_ABS_PYTHON_MODULE_PATH "${_ABS_PYTHON_MODULE_PATH}" ABSOLUTE) |
56 | | - FILE(RELATIVE_PATH _REL_PYTHON_MODULE_PATH ${CMAKE_INSTALL_PREFIX} ${_ABS_PYTHON_MODULE_PATH}) |
57 | | - SET(PYTHON_MODULE_PATH ${_REL_PYTHON_MODULE_PATH}) |
| 75 | + GET_FILENAME_COMPONENT(_ABS_PYTHON_MODULE_PATH |
| 76 | + "${_ABS_PYTHON_MODULE_PATH}" ABSOLUTE) |
| 77 | + FILE(RELATIVE_PATH _REL_PYTHON_MODULE_PATH |
| 78 | + ${CMAKE_INSTALL_PREFIX} ${_ABS_PYTHON_MODULE_PATH}) |
| 79 | + SET(PYTHON_MODULE_PATH ${_REL_PYTHON_MODULE_PATH}) |
58 | 80 |
|
59 | | - ############### INSTALL HEADERS & LIBRARY ################ |
60 | | - ### Install Python bindings |
61 | | - INSTALL(TARGETS _openshot DESTINATION ${PYTHON_MODULE_PATH} ) |
62 | | - INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/openshot.py DESTINATION ${PYTHON_MODULE_PATH} ) |
| 81 | + ############### INSTALL HEADERS & LIBRARY ################ |
| 82 | + ### Install Python bindings |
| 83 | + INSTALL(TARGETS ${SWIG_MODULE_pyopenshot_REAL_NAME} |
| 84 | + LIBRARY DESTINATION ${PYTHON_MODULE_PATH} ) |
| 85 | + INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/openshot.py |
| 86 | + DESTINATION ${PYTHON_MODULE_PATH} ) |
63 | 87 |
|
64 | | - ENDIF(PYTHONINTERP_FOUND) |
65 | | -ENDIF (PYTHONLIBS_FOUND) |
| 88 | +endif () |
0 commit comments