日期:2014-05-16  浏览次数:20685 次

Makefile中的一个问题
XML code

%.d: %.c
    @set -e; rm -f $@; \
         $(CC) -M $(CPPFLAGS) $< >; $@.$$$$; \
         sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ >; $@; \
         rm -f $@.$$$$


请大家帮忙解读一下sed那行,谢谢!

------解决方案--------------------
$(CC) -M 生成的dep文件有如下的格式。
假设源文件为hello.c
C/C++ code

hello.o: hello.c
hello.o: /usr/include/stdio.h

------解决方案--------------------
$* 不包含扩展名的目标文件名称。
查查makefile就知道了
------解决方案--------------------
sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ >; $@; \
把$@.$$$$中$*.o[:]*全局替换成 1.o,