summaryrefslogtreecommitdiffstats
path: root/modules/TDEMacros.cmake
diff options
context:
space:
mode:
authorSlávek Banko <slavek.banko@axis.cz>2022-01-14 04:12:30 +0100
committerSlávek Banko <slavek.banko@axis.cz>2022-01-14 15:28:59 +0100
commit2878ceef0ca6d857687db520bcb8aa6778834be8 (patch)
tree04cc91ce328b5bdf07e9727b7dc399cb05a7837b /modules/TDEMacros.cmake
parent321dec8aae24417f94637ed07b0e226fb5384290 (diff)
downloadtde-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.cmake42
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 )