CMake 脚本的命名约定是什么?

What is the naming convention for CMake scripts?

我知道 CMake 使用标准名称 "CMakeLists.txt" 和 add_subdirectory 函数在构建过程中直接调用脚本。

我有一些 CMake 代码,用于将文件转换为 C++ 字符串,然后可以使用 #include 指令将其烘焙到程序中。我的根 CMakeLists 文件中的相关代码如下所示(当然已大大简化):

add_custom_command(
  OUTPUT ${CMAKE_BINARY_DIR}/path/to/example.json.txt
  COMMAND ${CMAKE_COMMAND} ${CMAKE_SOURCE_DIR} ${CMAKE_BINARY_DIR} ${STRING_PATH} -P BuildString.cmake
  DEPENDS ${CMAKE_SOURCE_DIR}/path/to/example.json
  WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
)
add_custom_target(strings DEPENDS ${CMAKE_BINARY_DIR}/path/to/example.json.txt)

(在实际代码中,我为每个需要转换为字符串的文件调用add_custom_command,然后将所有输出文件名作为列表传递给add_custom_target。)

这里是 BuildString.cmake:

set(DELIMITER "")

set(SOURCE ${CMAKE_ARGV1})
set(BUILD ${CMAKE_ARGV2})
set(PATH ${CMAKE_ARGV3})

file(READ ${SOURCE}/${PATH} STRING)
# add semicolons back into string
string(REGEX REPLACE ";" "\\;" STRING "${STRING}")
file(WRITE ${BUILD}/${PATH}.txt R\"${DELIMITER}\(${STRING}\)${DELIMITER}\")

如您所见,BuildString.cmake 只获取一个输入文件并将该文件的内容(使用 ${DELIMITER} 作为分隔符包装在 C++ 原始字符串文字符号中)输出到构建目录中。

我应该怎么称呼BuildString.cmake?惯例是使用所有带下划线的小写字母 (build_string.cmake),还是使用小驼峰字母 (buildString.cmake)?或者名称应该是名词而不是动词 (StringBuilder.cmake)?

(附带说明,如果您能看到我可以改进任何此代码的不相关方式,那也将不胜感激。)

CMake 模块有一个约定:snake-case function_or_macro() 在 CamelCase FunctionOrMacro.cmake 文件中实现。因此,如有疑问,请使用 CamelCase。

并使用动词,名词用于类。