+ -
当前位置:首页 → 问答吧 → Makefile中自动处理头文件的依赖关系语句

Makefile中自动处理头文件的依赖关系语句

时间:2011-12-15

来源:互联网

makefile中的动态处理头文件依赖关系中产生.d文件的语句:
%.d: %.c
set -e; rm -f $@; \
$(CC) -MM $(CPPFLAGS) $< > $@.$$$$; \
sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@; \
rm -f $@.$$$$
无意中发现,若头文件中有以o结尾的就会出错。比如gcc -MM a.c输出
a.o: a.c hello.h a.h
那么上面会改成
a.o a.d: a.c hela.o a.d .h a.h
对\($*\).o的匹配不太明白,还有\1指的是哪部分啊?是s/XX/YY/g中的XX部分么?
再如echo "111(222)333" | sed 's/(\(.*\))/\1\1/g'
输出111222222333
各位能不能解释一下。
还有就是$*和.* 什么区别啊?

作者: CNprober   发布时间: 2011-12-15

$*是脚本的命令行参数
.*是正则表达式,意思是一个任意字符出现0到多次。

作者: qq120848369   发布时间: 2011-12-15