2010-01-28 70 views
0

我已经发布了我的makefile的相关位。当我在此生成文件上运行make all时,在编译debugosd.o时出现编译错误。但是,因为make找到了以前建造的debugosd.o,它只是继续构建dialup.otz如何编译一个依赖失败时强制退出?

没有删除所有的.o's,我如何强制debugosd.o变得过时 - 所以强制make一旦遇到debugosd.o中的编译错误就会停止运行?

构建.o文件的规则是:

%.o: %.c 
    $(TITLE) 
    $(CC) $(COMPILE) $(C_OPTIONS) -c $< 

而且makefile的片段是:

all: shared0.flw shared1.flw shared2.flw shared3.flw 

debugosd.o: debugosd.c debugosd.h 
xdialler_interface_new.o: xdialler_interface.h 
dialup.ooo: xdialler_interface_new.o debugosd.o xDialler.a 
    $(TITLE) 
    $(MAKE_OOO) 

dialup.otz: dialup.ooo 
    $(BIN)opress $< 

shared1.dir: dialup.otz 
    $(TITLE) 
    $(BIN)dirbuild $(SHAREDDIR1_OPTIONS) 

shared1.flw: shared1.dir 
    $(TITLE) 
    $(BIN)flwbuild $(SHAREDFLW_OPTIONS1) 

其实,我想通了什么问题了。我使用虚假目标强制重建shared1.flw。我认为这是迫使make继续不管错误。

+0

奇怪的是,我以为make就已经这样做了。 – Pace 2010-01-28 14:19:14

+0

是的,我也是 - 继续构建shared2.flw和shared3.flw。 – BeeBand 2010-01-28 14:25:36

回答

1

您没有列出debugosd.o的特定子命令,所以我假设它使用默认值,某处(如.c.o)。

如果任何子命令返回非零退出代码,应该退出,除非该命令以-开头。检查用于dubugosd.o目标的实际命令。

是否有先前建立的文件不应该有问题,make应该在出错条件后进行。