CMake命令之add_custom_comand 和 add_custom_target
一、背景
在很多時(shí)候,需要在cmake中創(chuàng)建一些目標(biāo),如clean、copy等等,這就需要通add_custom_target來指定。而add_custom_command則可以用來完成對add_custom_target生成的target的補(bǔ)充。?
二、add_custom_target命令
命令的功能:添加一個(gè)沒有輸出的目標(biāo),使得它始終被構(gòu)建。類似于makefile里面的
target ... : prerequisites ... command1command2command3...其中:
??? target是下面的命令的目標(biāo),即下面命令是為了target而生的。這個(gè)目標(biāo)可以是*.o文件,也可以是可執(zhí)行文件;
 ??? prerequisites則是生成該目標(biāo)所依賴的文件,如果找不到依賴的文件,下面的命令就不會(huì)執(zhí)行,并且會(huì)中斷make的生成;
 ??? command就是生成目標(biāo)文件的命令,一般就是編譯命令。
那么,如果使用CMakeLists.txt如何也生成一個(gè)目標(biāo)來make呢?
這就是add_custom_target的用處:增加一個(gè)沒有輸出的目標(biāo),使得它總是被構(gòu)建。
add_custom_target(Name [ALL] [command1 [args1...]][COMMAND command2 [args2...] ...][DEPENDS depend depend depend ... ][BYPRODUCTS [files...]][WORKING_DIRECTORY dir][COMMENT comment][JOB_POOL job_pool][VERBATIM] [USES_TERMINAL][COMMAND_EXPAND_LISTS][SOURCES src1 [src2...]])add_custom_comand的其他參數(shù)含義:
ALL:表明該目標(biāo)會(huì)被添加到默認(rèn)的構(gòu)建目標(biāo),使得它每次都被運(yùn)行;COMMAND:指定要在構(gòu)建時(shí)執(zhí)行的命令行;DEPENDS:指定命令所依賴的文件;COMMENT:在構(gòu)建時(shí)執(zhí)行命令之前顯示給定消息;WORKING_DIRECTORY:使用給定的當(dāng)前工作目錄執(zhí)行命令。如果它是相對路徑,它將相對于對應(yīng)于當(dāng)前源目 錄的構(gòu)建樹目錄;BYPRODUCTS:指定命令預(yù)期產(chǎn)生的文件。乍一看,該命令有很多的參數(shù),但其實(shí)我們并不需要全部了解,甚至一般情況下只需要用到其中的兩三個(gè)
舉個(gè)例子
cmake_minimum_required(VERSION 3.0) project(test)add_custom_target(CopyTask ALLCOMMAND ${CMAKE_COMMAND} -E copy_directory ${CMAKE_CURRENT_SOURCE_DIR}/config COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_CURRENT_SOURCE_DIR}/log.txt COMMAND python ${CMAKE_CURRENT_SOURCE_DIR}/etc.py WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/etc)其中:${CMAKE_COMMAND}是CMake的路徑,-E使CMake運(yùn)行命令而不是構(gòu)建,copy_directory和copy是cmake_command_line,再后面兩個(gè)就是command_line的參數(shù)。
當(dāng)然,生成文件不僅僅只能是復(fù)制,還可以是其他的操作。而這些COMMAND操作,都在command_line中規(guī)定了,參考cmake_command_line。
這里還可以調(diào)用python腳本,或者其他的命令行命令。
 ?
二、add_custom_comand的介紹
它有兩種命令格式:
第一種是,添加自定義命令,來生成指定的OUTPUT文件。
add_custom_command(OUTPUT output1 [output2 ...]COMMAND command1 [ARGS] [args1...][COMMAND command2 [ARGS] [args2...] ...][MAIN_DEPENDENCY depend][DEPENDS [depends...]][BYPRODUCTS [files...]][IMPLICIT_DEPENDS <lang1> depend1[<lang2> depend2] ...][WORKING_DIRECTORY dir][COMMENT comment][DEPFILE depfile][JOB_POOL job_pool][VERBATIM] [APPEND] [USES_TERMINAL][COMMAND_EXPAND_LISTS])舉個(gè)例子,添加一個(gè)自定義命令來運(yùn)行someTool來生成out.c文件,然后將生成的源代碼編譯為庫的一部分。每當(dāng)in.txt更改時(shí),該生成規(guī)則將會(huì)重新運(yùn)行 。
add_custom_command(OUTPUT out.cCOMMAND someTool -i ${CMAKE_CURRENT_SOURCE_DIR}/in.txt-o out.cDEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/in.txtVERBATIM) add_library(myLib out.c)第二種是,將自定義的命令添加到目標(biāo)(比如lib庫或者可執(zhí)行文件)。
add_custom_command(TARGET <target>PRE_BUILD | PRE_LINK | POST_BUILDCOMMAND command1 [ARGS] [args1...][COMMAND command2 [ARGS] [args2...] ...][BYPRODUCTS [files...]][WORKING_DIRECTORY dir][COMMENT comment][VERBATIM] [USES_TERMINAL][COMMAND_EXPAND_LISTS])這種自定義的命令,可以設(shè)置在構(gòu)建這個(gè)目標(biāo)過程中的某些時(shí)刻。也就是就,這種場景可以在目標(biāo)構(gòu)建的過程中,添加一些額外執(zhí)行的命令。這些命令本身將會(huì)成為該目標(biāo)的一部分。注意,僅在目標(biāo)本身被構(gòu)建過程才會(huì)執(zhí)行。如果該目標(biāo)已經(jīng)構(gòu)建,命令將不會(huì)執(zhí)行。
那么這些時(shí)刻是什么呢?
如下表所示:
舉個(gè)例子,這里使用了POST_BUILD參數(shù),表示在可執(zhí)行文件被鏈接之后,someHasher會(huì)生成一個(gè)hash文件
add_executable(myExe myExe.c) add_custom_command(TARGET myExe POST_BUILDCOMMAND someHasher -i "$<TARGET_FILE:myExe>"-o "$<TARGET_FILE:myExe>.hash"VERBATIM)三、實(shí)例
set(TEST_FILE "log.txt")add_custom_command(OUTPUT ${TEST_FILE}COMMAND echo "Generating log.txt file..."COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_CURRENT_LIST_FILE} ${TEST_FILE}COMMENT "This is a test")add_custom_target(Test1 ALL DEPENDS ${TEST_FILE})add_custom_command(TARGET Test1PRE_BUILD COMMAND echo "executing a fake command"COMMENT "This command will be executed before building target Test1")參考:
add_custom_command — CMake 3.22.0 Documentation
add_custom_target — CMake 3.22.0 Documentation
CMake命令之a(chǎn)dd_custom_comand 和 add_custom_target_山莊來客的專欄-CSDN博客
【CMake】cmake的add_custom_command和add_custom_target指令_Yngz_Miao的博客-CSDN博客_add_custom_command
總結(jié)
以上是生活随笔為你收集整理的CMake命令之add_custom_comand 和 add_custom_target的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: Veristand制作Custom De
 - 下一篇: CMake之add_custom_tar