blob: 73831199b13c84594c214ba61762b7b7ddf16300 [file] [log] [blame]
Oscar Fuentese1ad0872008-09-26 04:40:32 +00001# LLVM_TARGET_DEFINITIONS must contain the name of the .td file to process.
2# Extra parameters for `tblgen' may come after `ofn' parameter.
3# Adds the name of the generated file to TABLEGEN_OUTPUT.
4
5macro(tablegen ofn)
Oscar Fuentesd97ea302009-07-13 21:35:00 +00006 file(GLOB local_tds "*.td")
7 file(GLOB_RECURSE global_tds "${LLVM_MAIN_SRC_DIR}/include/llvm/*.td")
Douglas Gregoraf3f5442009-03-16 21:35:18 +00008
Douglas Gregorba6fc632010-06-17 15:17:07 +00009 if (IS_ABSOLUTE ${LLVM_TARGET_DEFINITIONS})
10 set(LLVM_TARGET_DEFINITIONS_ABSOLUTE ${LLVM_TARGET_DEFINITIONS})
11 else()
12 set(LLVM_TARGET_DEFINITIONS_ABSOLUTE
13 ${CMAKE_CURRENT_SOURCE_DIR}/${LLVM_TARGET_DEFINITIONS})
14 endif()
Oscar Fuentes8c0cd082010-10-22 17:37:42 +000015 add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${ofn}.tmp
Oscar Fuentes8a116e02010-10-22 16:20:10 +000016 # Generate tablegen output in a temporary file.
Oscar Fuentes99b94892009-06-11 04:16:10 +000017 COMMAND ${LLVM_TABLEGEN_EXE} ${ARGN} -I ${CMAKE_CURRENT_SOURCE_DIR}
Oscar Fuentesbeb7a052008-11-21 00:18:45 +000018 -I ${LLVM_MAIN_SRC_DIR}/lib/Target -I ${LLVM_MAIN_INCLUDE_DIR}
Douglas Gregorba6fc632010-06-17 15:17:07 +000019 ${LLVM_TARGET_DEFINITIONS_ABSOLUTE}
Oscar Fuentes8a116e02010-10-22 16:20:10 +000020 -o ${CMAKE_CURRENT_BINARY_DIR}/${ofn}.tmp
Oscar Fuentes5b30f0a2011-01-03 20:01:32 +000021 # The file in LLVM_TARGET_DEFINITIONS may be not in the current
22 # directory and local_tds may not contain it, so we must
23 # explicitly list it here:
Oscar Fuentesd538e242011-02-03 20:57:36 +000024 DEPENDS ${LLVM_TABLEGEN_EXE} ${local_tds} ${global_tds}
25 ${LLVM_TARGET_DEFINITIONS_ABSOLUTE}
Oscar Fuentes8c0cd082010-10-22 17:37:42 +000026 COMMENT "Building ${ofn}..."
27 )
28 add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${ofn}
Oscar Fuentes8a116e02010-10-22 16:20:10 +000029 # Only update the real output file if there are any differences.
30 # This prevents recompilation of all the files depending on it if there
31 # aren't any.
32 COMMAND ${CMAKE_COMMAND} -E copy_if_different
33 ${CMAKE_CURRENT_BINARY_DIR}/${ofn}.tmp
34 ${CMAKE_CURRENT_BINARY_DIR}/${ofn}
Oscar Fuentes8c0cd082010-10-22 17:37:42 +000035 DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${ofn}.tmp
36 COMMENT ""
Oscar Fuentese1ad0872008-09-26 04:40:32 +000037 )
38 set(TABLEGEN_OUTPUT ${TABLEGEN_OUTPUT} ${CMAKE_CURRENT_BINARY_DIR}/${ofn})
Douglas Gregor4b738932009-06-25 05:03:06 +000039 set_source_files_properties(${CMAKE_CURRENT_BINARY_DIR}/${ofn}
40 PROPERTIES GENERATED 1)
Oscar Fuentese1ad0872008-09-26 04:40:32 +000041endmacro(tablegen)