diff options
author | Slávek Banko <slavek.banko@axis.cz> | 2022-01-14 04:12:30 +0100 |
---|---|---|
committer | Slávek Banko <slavek.banko@axis.cz> | 2022-01-14 15:28:59 +0100 |
commit | 2878ceef0ca6d857687db520bcb8aa6778834be8 (patch) | |
tree | 04cc91ce328b5bdf07e9727b7dc399cb05a7837b /modules/TDEMacros.cmake | |
parent | 321dec8aae24417f94637ed07b0e226fb5384290 (diff) | |
download | tde-cmake-2878ceef0ca6d857687db520bcb8aa6778834be8.tar.gz tde-cmake-2878ceef0ca6d857687db520bcb8aa6778834be8.zip |
tde_automoc: Add support for processing automoc for generated files.
Signed-off-by: Slávek Banko <slavek.banko@axis.cz>
(cherry picked from commit efec901634b3c9816f8788d48bf27c7511238855)
Diffstat (limited to 'modules/TDEMacros.cmake')
-rw-r--r-- | modules/TDEMacros.cmake | 42 |
1 files changed, 41 insertions, 1 deletions
diff --git a/modules/TDEMacros.cmake b/modules/TDEMacros.cmake index 9be9beb..2635fbd 100644 --- a/modules/TDEMacros.cmake +++ b/modules/TDEMacros.cmake @@ -498,13 +498,15 @@ macro( tde_automoc ) endforeach( ) if( NOT _found ) get_filename_component( _moc_file "${_moc_file}" NAME ) - tde_message_fatal( "AUTOMOC error: '${_moc_file}' cannot be generated.\n Reason: '${_src_file}.h' not found." ) + tde_message_fatal( "AUTOMOC error: '${_moc_file}' cannot be generated.\n Reason: '${_src_header}.h' not found." ) endif( ) endif( ) # moc-ing header + file( RELATIVE_PATH _moc_file_relative "${CMAKE_BINARY_DIR}" "${_moc_file}" ) add_custom_command( OUTPUT ${_moc_file} COMMAND ${TMOC_EXECUTABLE} ${_header_file} -o ${_moc_file} + COMMENT "Generating ${_moc_file_relative}" DEPENDS ${_header_file} ) # create dependency between source file and moc file @@ -514,6 +516,44 @@ macro( tde_automoc ) endif( _moc_includes ) + else( EXISTS "${_src_file}" ) + + # for generated file, the path must match the binary directory + string( LENGTH "${CMAKE_BINARY_DIR}" CMAKE_BINARY_DIR_LEN ) + string( LENGTH "${_src_file}" _basename_len ) + if( ${_basename_len} LESS ${CMAKE_BINARY_DIR_LEN} ) + set( _basedir_prefix "${CMAKE_SOURCE_DIR}" ) + else( ) + string( SUBSTRING "${_src_file}" 0 ${CMAKE_BINARY_DIR_LEN} _basedir_prefix ) + endif( ) + if( ${_basedir_prefix} STREQUAL "${CMAKE_BINARY_DIR}" ) + file( RELATIVE_PATH _sourcename "${CMAKE_BINARY_DIR}" "${_src_file}" ) + file( RELATIVE_PATH _basename "${CMAKE_CURRENT_BINARY_DIR}" "${_src_file}" ) + else( ) + file( RELATIVE_PATH _sourcename "${CMAKE_SOURCE_DIR}" "${_src_file}" ) + file( RELATIVE_PATH _basename "${CMAKE_CURRENT_SOURCE_DIR}" "${_src_file}" ) + endif( ) + + # automocing generated file + get_filename_component( _automoc_file "${_src_file}+automoc" NAME ) + set( _automoc_file "${CMAKE_CURRENT_BINARY_DIR}/${_automoc_file}" ) + + add_custom_command( OUTPUT ${_automoc_file} + COMMAND ${CMAKE_COMMAND} + -DTMOC_EXECUTABLE:FILEPATH=${TMOC_EXECUTABLE} + -DSRC_FILE:FILEPATH=${CMAKE_CURRENT_BINARY_DIR}/${_basename} + -DMETA_INCLUDES:STRING="${_meta_includes}" + -DMASTER_SOURCE_DIR:FILEPATH=${CMAKE_SOURCE_DIR} + -DMASTER_BINARY_DIR:FILEPATH=${CMAKE_BINARY_DIR} + -P ${TDE_CMAKE_MODULES}/tde_automoc.cmake + COMMENT "Automocing ${_sourcename}" + DEPENDS "${CMAKE_CURRENT_BINARY_DIR}/${_basename}" + ) + + # create dependency between source file and moc file + set_property( SOURCE "${CMAKE_CURRENT_BINARY_DIR}/${_basename}" + APPEND PROPERTY OBJECT_DEPENDS ${_automoc_file} ) + endif( EXISTS "${_src_file}" ) endforeach( _src_file ) |