我正在将GNU Make makefile翻译成Microsoft Visual Studio Makefile。我有三个疑问:
1)如何替换字符串。例如,在包含以下内容的文件夹中
namespace_type_function1.cpp
namespace_type_function2.cpp
namespace_type_function3.cpp
我想改变类型让我们说“INT”字符串,所以我终于得到了
namespace_INT_function1.cpp
namespace_INT_function2.cpp
namespace_INT_function3.cpp
2)如何以类似的方式添加前缀 3.如何以相同的方式添加后缀。
答案 0 :(得分:7)
在环境变量或内部nmake变量中包含字符串后,可以使用以下内容将一个固定字符串替换为另一个:
$(MY_VAR:REPLACE_THIS=WITH_THIS)
“WITH_THIS”可以是空字符串。
示例makefile:
MY_VAR=123451234512345
ALL:
@echo $(MY_VAR:12=XX)
@echo $(MY_VAR:12=)
输出:
XX345XX345XX345
345345345
来自Microsoft文档:
宏替换区分大小写并且是字面的; string1和 string2无法调用宏。替换不会改变 原始定义。您可以替换任何预定义宏中的文本 除了
$$@
。冒号前面没有空格或制表符;结肠后的任何一个 解释为文字。如果string2为null,则所有出现的string1 从宏的定义字符串中删除。
答案 1 :(得分:4)
除了子字符串替换之外,NMAKE没有很多字符串处理,甚至这也不能执行宏扩展。但是,由于NMAKE支持包含makefile,因此可以使用一种明显的技术,尽管它的实现有点复杂。
这个想法是创建一个临时的makefile,它通过包含在递归调用中,在需要的地方执行另一个宏扩展。这可用于将变量前缀,后缀或分隔符添加到字符串列表中。如有必要,可以进行进一步的扩展轮次。
以下代码段说明了该方法。它将列表a b c d e
转换为[a];[b];[c];[d];[e]
(即,在元素之间添加前缀,后缀和分隔符)。原始makefile(如果NMAKE支持二次扩展将执行的规则)基本不变。最后,NMAKE在整个运行后不会留下任何临时文件。
# The name of the makefile.
MAKEFILE = test.mak
# The list of strings to be processed. The elements can be separated by one or more spaces or tabs.
LIST = a b c d e
# The prefix to add to each element.
PREFIX = [
# The suffix to add to each element.
SUFFIX = ]
# The separator to add between each element.
SEP = ;
#####
# Replace tabs with spaces.
# Note: there is a hard tab character between the colon and the equal sign.
LIST = $(LIST: = )
!IFNDEF TEMPFILE
# Write a temporary makefile.
target1 target2:
@$(MAKE) /nologo /C /$(MAKEFLAGS) /F$(MAKEFILE) TEMPFILE=<< $@
LIST = $(PREFIX)$$(LIST: =$(SUFFIX)$(SEP)$(PREFIX))$(SUFFIX)
LIST = $$(LIST:$(PREFIX)$(SUFFIX)$(SEP)=)
<<NOKEEP
!ELSE
# Here goes your original makefile.
! INCLUDE $(TEMPFILE)
target1:
@echo.$@
@echo.$(LIST)
target2:
@echo.$@
@echo.$(LIST)
!ENDIF
唯一需要注意的是,命令行宏不传递给递归调用,因此不再有用。