【问题】
在写makefile的时候,发现如下代码:release_pdf:$(OUTPUT_FILE_PDF)
@echo "=============================== release pdf =============================="
cp -a $(OUTPUT_FILE_PDF) $(RELEASE_DIR_PDF)
echo $(@:release_=)
$(COMPRESS_TOOL) $(COMPRESS_FLAG) $(RELEASE_DIR_PDF)/$(PROJECT_NAME).$(@:release_=).$(COMPRESS_SUF) $(OUTPUT_FILE_PDF)
中的echo 部分,没有输出所期望的pdf,而是输出整个的release_pdf
其中,当前环境是:CLi@PC-CLI-1 ~/develop/docbook/books/mpeg_vbr/src
$ make --version
GNU Make 3.82.90
Built for i686-pc-cygwin
Copyright (C) 2010 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
CLi@PC-CLI-1 ~/develop/docbook/books/mpeg_vbr/src
$ uname -a
CYGWIN_NT-6.1-WOW64 PC-CLI-1 1.7.14(0.260/5/3) 2012-04-25 09:41 i686 Cygwin
【解决过程】
1.首先要说的是,这种用法,是之前参考Uboot的makefile中的写法:
而写出来的,可以确保我的写法是正确的,应该是可以工作的。但是实际结果是试了半天,都还是没有效果。
2.关于makefile中的替换的用法,这里也有解释:
Makefile变量的替换引用
但是我此处的始终是无法工作。
对应的想要实现替换功能,只能用:$(subst release_,,$@)
才可以实现,从release_pdf得到pdf。
3.目前,怀疑是cygwin中该make有bug。有待以后确认。
【后记】
后来无意间去试了试此方法,对于同一makefile中的另外一处:
################################################################################
# html
################################################################################
$(OUTPUT_FILE_HTML):$(MAIN_SRC_FILE) $(SUB_SRC_FILES)
echo $(@:.html=)
结果,上述代码,是可以正常输出所想要的结果的:echo ../output/html/single/linux_nand_driver
../output/html/single/linux_nand_driver
其中:
OUTPUT_FILE_HTML=../output/html/single/linux_nand_driver.hml
经过:$(@:.html=)
就变成了:
../output/html/single/linux_nand_driver
所以是正常的。
而再回去看看原先的release_pdf没有变成pdf,觉得唯一的解释是:
【可能是:由于@所表示的目标,只是一个标号,而非真实的目标依赖文件,所以无法用$(@:aaa=bbb)去实现替换功能】
即:
@表示目标文件,只能对目标文件进行用等于号”=”替换,所以:
1. 可以用:
$(@:.html=)
将目标文件:
../output/html/single/linux_nand_driver.hml
替换为:
=../output/html/single/linux_nand_driver
2.而由于release_pdf只是目标,但不是一个实际存在的文件,所以不可以用:
$(@:release_=)
对目标名字:
release_pdf
进行替换,无法替换为所希望的pdf,所以得到的结果就是原先字符串release_pdf了。