微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

makefile – 在gnu make中,静态模式规则中的先决条件可以具有不同的后缀

我们的make文件使用静态模式规则编译.c源文件,如下所示:
OBJECTS = foo.o bar.o baz.o

$(OBJECTS): %.o: %.c
    $(CC) $< $(C_OPTIONS) -c -o $@

我需要将其中一个.c文件更改为Objective-C .m文件.对两种源类型调用编译器是相同的,所以我想使用相同的规则并调整它以使其更灵活.我宁愿不更改OPTIONS变量,因为它也用于链接步骤等.

有没有办法使上面的规则更灵活,以适应.c和.m文件

谢谢

解决方法

我们可以将这个或者行为添加到事物列表中,Make应该能够轻松完成,但事实并非如此.这是一种方法,使用“eval”为每个对象创建一个单独的规则.
define RULE_template
$(1): $(wildcard $(basename $(1)).[cm])
endef

OBJECTS = foo.o bar.o baz.o

$(foreach obj,$(OBJECTS),$(eval $(call RULE_template,$(obj))))

$(OBJECTS):
    $(CC) $&lt $(C_OPTIONS) -c -o $@ 

请注意,这取决于运行Make之前已存在的源文件(foo.c或foo.m,但不是两者).如果您在同一步骤中生成这些源,则无效.

这是一种不太聪明,更健壮的方法.

CPP_OBJECTS = foo.o bar.o
OBJECTIVE_OBJECTS = baz.o
OBJECTS = $(CPP_OBJECTS) $(OBJECTIVE_OBJECTS)

$(CPP_OBJECTS): %.o: %.c 

$(OBJECTIVE_OBJECTS): %.o: %.m 

$(OBJECTS):
    $(CC) $&lt $(C_OPTIONS) -c -o $@ 

编辑:纠正了OBJECTS任务,感谢Jonathan Leffler.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐