From f2b7bb7aa8a67046c6ac2f1d06e2705f36f6d8fa Mon Sep 17 00:00:00 2001 From: Laurent Montel Date: Mon, 20 Oct 2008 07:25:56 +0000 Subject: Move here svn path=/trunk/KDE/kdelibs/; revision=873796 --- modules/PythonMacros.cmake | 57 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 modules/PythonMacros.cmake (limited to 'modules/PythonMacros.cmake') diff --git a/modules/PythonMacros.cmake b/modules/PythonMacros.cmake new file mode 100644 index 00000000..c97450d7 --- /dev/null +++ b/modules/PythonMacros.cmake @@ -0,0 +1,57 @@ +# Python macros +# ~~~~~~~~~~~~~ +# Copyright (c) 2007, Simon Edwards +# +# Redistribution and use is allowed according to the terms of the BSD license. +# For details see the accompanying COPYING-CMAKE-SCRIPTS file. +# +# This file defines the following macros: +# +# PYTHON_INSTALL (SOURCE_FILE DESINATION_DIR) +# Install the SOURCE_FILE, which is a Python .py file, into the +# destination directory during install. The file will be byte compiled +# and both the .py file and .pyc file will be installed. + +GET_FILENAME_COMPONENT(PYTHON_MACROS_MODULE_PATH ${CMAKE_CURRENT_LIST_FILE} PATH) + +MACRO(PYTHON_INSTALL SOURCE_FILE DESINATION_DIR) + + FIND_FILE(_python_compile_py PythonCompile.py PATHS ${CMAKE_MODULE_PATH}) + + ADD_CUSTOM_TARGET(compile_python_files ALL) + + # Install the source file. + INSTALL(FILES ${SOURCE_FILE} DESTINATION ${DESINATION_DIR}) + + # Byte compile and install the .pyc file. + GET_FILENAME_COMPONENT(_absfilename ${SOURCE_FILE} ABSOLUTE) + GET_FILENAME_COMPONENT(_filename ${SOURCE_FILE} NAME) + GET_FILENAME_COMPONENT(_filenamebase ${SOURCE_FILE} NAME_WE) + GET_FILENAME_COMPONENT(_basepath ${SOURCE_FILE} PATH) + SET(_bin_py ${CMAKE_CURRENT_BINARY_DIR}/${_basepath}/${_filename}) + SET(_bin_pyc ${CMAKE_CURRENT_BINARY_DIR}/${_basepath}/${_filenamebase}.pyc) + + FILE(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/${_basepath}) + + SET(_message "-DMESSAGE=Byte-compiling ${_bin_py}") + + GET_FILENAME_COMPONENT(_abs_bin_py ${_bin_py} ABSOLUTE) + IF(_abs_bin_py STREQUAL ${_absfilename}) # Don't copy the file onto itself. + ADD_CUSTOM_COMMAND( + TARGET compile_python_files + COMMAND ${CMAKE_COMMAND} ${_message} -P ${PYTHON_MACROS_MODULE_PATH}/print_status.cmake + COMMAND ${PYTHON_EXECUTABLE} ${_python_compile_py} ${_bin_py} + DEPENDS ${_absfilename} + ) + ELSE(_abs_bin_py STREQUAL ${_absfilename}) + ADD_CUSTOM_COMMAND( + TARGET compile_python_files + COMMAND ${CMAKE_COMMAND} ${_message} -P ${PYTHON_MACROS_MODULE_PATH}/print_status.cmake + COMMAND ${CMAKE_COMMAND} -E copy ${_absfilename} ${_bin_py} + COMMAND ${PYTHON_EXECUTABLE} ${_python_compile_py} ${_bin_py} + DEPENDS ${_absfilename} + ) + ENDIF(_abs_bin_py STREQUAL ${_absfilename}) + + INSTALL(FILES ${_bin_pyc} DESTINATION ${DESINATION_DIR}) +ENDMACRO(PYTHON_INSTALL) -- cgit v1.2.1 From 3ccbe08963ff10657585b2a7ba79825b245c424a Mon Sep 17 00:00:00 2001 From: Laurent Montel Date: Tue, 21 Oct 2008 06:46:12 +0000 Subject: Bye bye print_status.cmake svn path=/trunk/KDE/kdelibs/; revision=874282 --- modules/PythonMacros.cmake | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'modules/PythonMacros.cmake') diff --git a/modules/PythonMacros.cmake b/modules/PythonMacros.cmake index c97450d7..fa9b2ba7 100644 --- a/modules/PythonMacros.cmake +++ b/modules/PythonMacros.cmake @@ -39,14 +39,14 @@ MACRO(PYTHON_INSTALL SOURCE_FILE DESINATION_DIR) IF(_abs_bin_py STREQUAL ${_absfilename}) # Don't copy the file onto itself. ADD_CUSTOM_COMMAND( TARGET compile_python_files - COMMAND ${CMAKE_COMMAND} ${_message} -P ${PYTHON_MACROS_MODULE_PATH}/print_status.cmake + COMMAND ${CMAKE_COMMAND} -E echo ${message} COMMAND ${PYTHON_EXECUTABLE} ${_python_compile_py} ${_bin_py} DEPENDS ${_absfilename} ) ELSE(_abs_bin_py STREQUAL ${_absfilename}) ADD_CUSTOM_COMMAND( TARGET compile_python_files - COMMAND ${CMAKE_COMMAND} ${_message} -P ${PYTHON_MACROS_MODULE_PATH}/print_status.cmake + COMMAND ${CMAKE_COMMAND} -E echo ${message} COMMAND ${CMAKE_COMMAND} -E copy ${_absfilename} ${_bin_py} COMMAND ${PYTHON_EXECUTABLE} ${_python_compile_py} ${_bin_py} DEPENDS ${_absfilename} -- cgit v1.2.1 From 7a2d02b259024c74e6fd7a34822b2824af1b1789 Mon Sep 17 00:00:00 2001 From: Carlo Segato Date: Wed, 17 Dec 2008 23:40:49 +0000 Subject: remove the drive letter from the path on windows, since we can't make a directory named 'c:/path/' svn path=/trunk/KDE/kdelibs/; revision=898330 --- modules/PythonMacros.cmake | 4 ++++ 1 file changed, 4 insertions(+) (limited to 'modules/PythonMacros.cmake') diff --git a/modules/PythonMacros.cmake b/modules/PythonMacros.cmake index fa9b2ba7..96d9cd35 100644 --- a/modules/PythonMacros.cmake +++ b/modules/PythonMacros.cmake @@ -31,6 +31,10 @@ MACRO(PYTHON_INSTALL SOURCE_FILE DESINATION_DIR) SET(_bin_py ${CMAKE_CURRENT_BINARY_DIR}/${_basepath}/${_filename}) SET(_bin_pyc ${CMAKE_CURRENT_BINARY_DIR}/${_basepath}/${_filenamebase}.pyc) + if(WIN32) + string(REGEX REPLACE ".:/" "/" _basepath "${_basepath}") + endif(WIN32) + FILE(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/${_basepath}) SET(_message "-DMESSAGE=Byte-compiling ${_bin_py}") -- cgit v1.2.1 From ecb937b3ac82ba3236537186ed728eb4e5d0ca23 Mon Sep 17 00:00:00 2001 From: Carlo Segato Date: Thu, 18 Dec 2008 00:00:12 +0000 Subject: move the drive letter replace a bit higher svn path=/trunk/KDE/kdelibs/; revision=898341 --- modules/PythonMacros.cmake | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'modules/PythonMacros.cmake') diff --git a/modules/PythonMacros.cmake b/modules/PythonMacros.cmake index 96d9cd35..4ae5a3c7 100644 --- a/modules/PythonMacros.cmake +++ b/modules/PythonMacros.cmake @@ -28,13 +28,14 @@ MACRO(PYTHON_INSTALL SOURCE_FILE DESINATION_DIR) GET_FILENAME_COMPONENT(_filename ${SOURCE_FILE} NAME) GET_FILENAME_COMPONENT(_filenamebase ${SOURCE_FILE} NAME_WE) GET_FILENAME_COMPONENT(_basepath ${SOURCE_FILE} PATH) - SET(_bin_py ${CMAKE_CURRENT_BINARY_DIR}/${_basepath}/${_filename}) - SET(_bin_pyc ${CMAKE_CURRENT_BINARY_DIR}/${_basepath}/${_filenamebase}.pyc) if(WIN32) string(REGEX REPLACE ".:/" "/" _basepath "${_basepath}") endif(WIN32) + SET(_bin_py ${CMAKE_CURRENT_BINARY_DIR}/${_basepath}/${_filename}) + SET(_bin_pyc ${CMAKE_CURRENT_BINARY_DIR}/${_basepath}/${_filenamebase}.pyc) + FILE(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/${_basepath}) SET(_message "-DMESSAGE=Byte-compiling ${_bin_py}") -- cgit v1.2.1