summaryrefslogtreecommitdiff
path: root/cmake/DemoCodegen.cmake
diff options
context:
space:
mode:
Diffstat (limited to 'cmake/DemoCodegen.cmake')
-rw-r--r--cmake/DemoCodegen.cmake12
1 files changed, 9 insertions, 3 deletions
diff --git a/cmake/DemoCodegen.cmake b/cmake/DemoCodegen.cmake
index 2d21b14..32cb06c 100644
--- a/cmake/DemoCodegen.cmake
+++ b/cmake/DemoCodegen.cmake
@@ -236,10 +236,16 @@ add_custom_command(
add_custom_target(generate_demo_data DEPENDS ${GEN_DEMO_H}.data_stamp)
# Unified asset generation (triggered when any category changes)
+# assets.h is written via copy_if_different so its mtime only changes when the
+# enum content changes (e.g. new asset added). This prevents unrelated
+# translation units (audio, 3d, …) from recompiling on every shader edit.
+set(GEN_DEMO_H_STAMP ${GEN_DEMO_H}.gen_stamp)
add_custom_command(
- OUTPUT ${GEN_DEMO_H} ${GEN_DEMO_CC}
+ OUTPUT ${GEN_DEMO_H_STAMP} ${GEN_DEMO_CC}
COMMAND ${CMAKE_COMMAND} -E make_directory ${CMAKE_CURRENT_SOURCE_DIR}/src/generated
- COMMAND ${ASSET_PACKER_CMD} ${WORKSPACE_ASSETS} ${GEN_DEMO_H} ${GEN_DEMO_CC}
+ COMMAND ${ASSET_PACKER_CMD} ${WORKSPACE_ASSETS} ${GEN_DEMO_H}.new ${GEN_DEMO_CC}
+ COMMAND ${CMAKE_COMMAND} -E copy_if_different ${GEN_DEMO_H}.new ${GEN_DEMO_H}
+ COMMAND ${CMAKE_COMMAND} -E touch ${GEN_DEMO_H_STAMP}
DEPENDS ${ASSET_PACKER_DEPENDS} ${WORKSPACE_ASSETS}
${GEN_DEMO_H}.shaders_stamp
${GEN_DEMO_H}.audio_stamp
@@ -249,7 +255,7 @@ add_custom_command(
)
# Combined target for compatibility
-add_custom_target(generate_demo_assets DEPENDS ${GEN_DEMO_H} ${GEN_DEMO_CC})
+add_custom_target(generate_demo_assets DEPENDS ${GEN_DEMO_H_STAMP} ${GEN_DEMO_CC})
# Test assets (unchanged)
pack_test_assets(test_assets ${CMAKE_CURRENT_SOURCE_DIR}/workspaces/test/assets.txt GEN_TEST_H GEN_TEST_CC generate_test_assets)