2013-08-22 120 views
4

我正在翻译GNU Make makefile到Microsoft Visual Studio Makefile。我有三个疑问:如何替换字符串并在Microsoft NMake中添加前缀或后缀?

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

快速浏览[NMake文档](http://msdn.microsoft.com/en-us/library/dd9y37ha.aspx)表明这可能很困难,因为没有任何字符串处理的迹象。 – Richard

回答

6

一旦有了在任一环境变量或内部NMAKE变量的字符串,可以使用下面的替代一个固定字符串为另一:

$(MY_VAR:REPLACE_THIS=WITH_THIS) 

“WITH_THIS”可以是一个空字符串。

实施例生成文件:

MY_VAR=123451234512345 
ALL: 
    @echo $(MY_VAR:12=XX) 
    @echo $(MY_VAR:12=) 

输出:

XX345XX345XX345 
345345345 

从Microsoft文档:

宏替换是大小写敏感的,是文字; string1和 string2不能调用宏。替换不会修改原始定义。您可以使用除[email protected]之外的任何预定义宏 中的文本。

冒号前没有空格或制表符;任何冒号后面都是 解释为文字。如果string2为空,则从宏的定义字符串中删除所有出现的字符串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=<< [email protected] 
LIST = $(PREFIX)$$(LIST: =$(SUFFIX)$(SEP)$(PREFIX))$(SUFFIX) 
LIST = $$(LIST:$(PREFIX)$(SUFFIX)$(SEP)=) 
<<NOKEEP 

!ELSE 
# Here goes your original makefile. 
! INCLUDE $(TEMPFILE) 

target1: 
    @[email protected] 
    @echo.$(LIST) 

target2: 
    @[email protected] 
    @echo.$(LIST) 
!ENDIF 

从这个唯一要注意的是,命令行宏传递给递归调用,并且因此没有太大有用了。