From 6cac97aaa085f7a1196aa88b43ecb2cf8aee812c Mon Sep 17 00:00:00 2001 From: Jean-Christophe Fillion-Robin Date: Wed, 20 Mar 2024 14:38:45 -0400 Subject: [PATCH] ENH: Revisit approach introducing CTK_COMPILE_PYTHON_SCRIPT_KEEP_ONLY_PYC --- CMake/ctkMacroCompilePythonScript.cmake | 46 +++++++++++++---------- CMake/ctk_compile_python_scripts.cmake.in | 2 + CMakeLists.txt | 4 +- 3 files changed, 30 insertions(+), 22 deletions(-) diff --git a/CMake/ctkMacroCompilePythonScript.cmake b/CMake/ctkMacroCompilePythonScript.cmake index c4f411cb48..5e89bf2376 100644 --- a/CMake/ctkMacroCompilePythonScript.cmake +++ b/CMake/ctkMacroCompilePythonScript.cmake @@ -18,13 +18,16 @@ # include(${CTK_CMAKE_DIR}/ctkMacroParseArguments.cmake) +if(${CMAKE_VERSION} VERSION_LESS "3.5") + include(CMakeParseArguments) +endif() set(CTK_PYTHON_COMPILE_FILE_SCRIPT_DIR "${CMAKE_BINARY_DIR}/CMakeFiles") -# Setting this option to TRUE disable the copy of ".py" files into the -# destination directory associated with ctkMacroCompilePythonScript. -if(NOT DEFINED CTK_COMPILE_PYTHON_SCRIPT_SKIP_SCRIPT_COPY) - set(CTK_COMPILE_PYTHON_SCRIPT_SKIP_SCRIPT_COPY FALSE) +# Setting this option to TRUE remove the relevant ".py" files from the +# destination directory after they have been byte-compiled in ctkMacroCompilePythonScript. +if(NOT DEFINED CTK_COMPILE_PYTHON_SCRIPT_KEEP_ONLY_PYC) + set(CTK_COMPILE_PYTHON_SCRIPT_KEEP_ONLY_PYC FALSE) endif() #! \ingroup CMakeAPI @@ -104,11 +107,11 @@ macro(ctkMacroCompilePythonScript) USE_SOURCE_PERMISSIONS) if(NOT MY_GLOBAL_TARGET) - set(_skip_script_copy_option) - if(CTK_COMPILE_PYTHON_SCRIPT_SKIP_SCRIPT_COPY) - set(_skip_script_copy_option SKIP_SCRIPT_COPY) + set(_keep_only_pyc_option) + if(CTK_COMPILE_PYTHON_SCRIPT_KEEP_ONLY_PYC) + set(_keep_only_pyc_option KEEP_ONLY_PYC) endif() - ctkFunctionAddCompilePythonScriptTargets(${target} ${_skip_script_copy_option}) + ctkFunctionAddCompilePythonScriptTargets(${target} ${_keep_only_pyc_option}) endif() endmacro() @@ -141,7 +144,7 @@ function(_ctk_add_copy_python_files_target target type) endfunction() -function(_ctk_add_compile_python_directories_target target) +function(_ctk_add_compile_python_directories_target target keep_only_pyc) set(target_name Compile${target}PythonFiles) if(NOT TARGET ${target_name}) # Byte compile the Python files. @@ -155,7 +158,10 @@ function(_ctk_add_compile_python_directories_target target) list(GET tuple 1 tgt_file) list(GET tuple 2 dest_dir) set(tgt ${dest_dir}/${tgt_file}) - set(_compileall_code "${_compileall_code}\nctk_compile_file('${tgt}', force=1)") + set(_compileall_code "${_compileall_code}\nsuccess = ctk_compile_file('${tgt}', force=1)") + if(keep_only_pyc) + set(_compileall_code "${_compileall_code}\nif success: Path('${tgt}').unlink()") + endif() endforeach() if(NOT PYTHONINTERP_FOUND) @@ -193,15 +199,15 @@ function(_ctk_add_compile_python_directories_target target) endfunction() function(ctkFunctionAddCompilePythonScriptTargets target) - ctkMacroParseArguments(MY - "" - "SKIP_SCRIPT_COPY" - ${ARGN} + set(options + KEEP_ONLY_PYC ) - # Skip defining the target CopySlicerPythonScriptFiles when the argument skip_script_copy is set to True - if(NOT MY_SKIP_SCRIPT_COPY) - _ctk_add_copy_python_files_target(${target} Script ${ARGN}) - endif() - _ctk_add_copy_python_files_target(${target} Resource ${ARGN}) - _ctk_add_compile_python_directories_target(${target}) + set(oneValueArgs + ) + set(multiValueArgs + ) + cmake_parse_arguments(MY "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN}) + _ctk_add_copy_python_files_target(${target} Script ${MY_UNPARSED_ARGUMENTS}) + _ctk_add_copy_python_files_target(${target} Resource ${MY_UNPARSED_ARGUMENTS}) + _ctk_add_compile_python_directories_target(${target} ${MY_KEEP_ONLY_PYC}) endfunction() diff --git a/CMake/ctk_compile_python_scripts.cmake.in b/CMake/ctk_compile_python_scripts.cmake.in index 211da0da1c..470b0bad36 100644 --- a/CMake/ctk_compile_python_scripts.cmake.in +++ b/CMake/ctk_compile_python_scripts.cmake.in @@ -21,6 +21,8 @@ import sys import py_compile import struct +from pathlib import Path + def ctk_compile_file(fullname, ddir=None, force=0, rx=None, quiet=0): \"\"\"Byte-compile one file. diff --git a/CMakeLists.txt b/CMakeLists.txt index 99dd8b1b72..41946940a1 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -747,9 +747,9 @@ mark_as_superbuild(CTK_ENABLE_Python_Wrapping) include(CMakeDependentOption) cmake_dependent_option( - CTK_COMPILE_PYTHON_SCRIPT_SKIP_SCRIPT_COPY "Disable copy of .py files when using ctkMacroCompilePythonScript()" OFF + CTK_COMPILE_PYTHON_SCRIPT_KEEP_ONLY_PYC "Remove .py scripts from destination directory after compiling to .pyc" OFF "CTK_ENABLE_Python_Wrapping" OFF) -mark_as_superbuild(CTK_COMPILE_PYTHON_SCRIPT_SKIP_SCRIPT_COPY) +mark_as_superbuild(CTK_COMPILE_PYTHON_SCRIPT_KEEP_ONLY_PYC) # Build examples # Create the logical expression containing the minimum set of required options