3 回答

TA貢獻1804條經驗 獲得超2個贊
在您的示例中,TMP只要評估了規則,out.tar便會設置變量(并創建臨時目錄)。為了僅在out.tar實際觸發時創建目錄,您需要將目錄創建移至以下步驟:
out.tar :
$(eval TMP := $(shell mktemp -d))
@echo hi $(TMP)/hi.txt
tar -C $(TMP) cf $@ .
rm -rf $(TMP)
該EVAL,如果它已經手動鍵入到makefile文件函數計算的字符串。在這種情況下,它將TMP變量設置為shell函數調用的結果。
編輯(回應評論):
要創建唯一變量,您可以執行以下操作:
out.tar :
$(eval $@_TMP := $(shell mktemp -d))
@echo hi $($@_TMP)/hi.txt
tar -C $($@_TMP) cf $@ .
rm -rf $($@_TMP)
這會將目標名稱(在本例中為out.tar)放在變量之前,從而產生一個名稱為的變量out.tar_TMP。希望這足以防止沖突。

TA貢獻1785條經驗 獲得超4個贊
另一種可能性是在規則觸發時使用單獨的行來設置Make變量。
例如,這是帶有兩個規則的makefile。如果規則觸發,它將創建一個臨時目錄并將TMP設置為該臨時目錄名稱。
PHONY = ruleA ruleB display
all: ruleA
ruleA: TMP = $(shell mktemp -d testruleA_XXXX)
ruleA: display
ruleB: TMP = $(shell mktemp -d testruleB_XXXX)
ruleB: display
display:
echo ${TMP}
運行代碼會產生預期的結果:
$ ls
Makefile
$ make ruleB
echo testruleB_Y4Ow
testruleB_Y4Ow
$ ls
Makefile testruleB_Y4Ow
- 3 回答
- 0 關注
- 605 瀏覽
添加回答
舉報