linux makefile中命令前加 “-” 的妙用

文章目录


前言

make执行的命令出错就立刻终止,不再执行后续命令,但是又想让后面的命令继续执行,该怎么处理。


举个栗子

在利用VCS进行仿真时,为了保证每次产生的文件都是最新生成的,通常会将输出的output文件夹删除,再新建一个同样名字的文件夹,用来保存新产生的输出和log文件。例如:

comp:
	rm -rf output;
	mkdir output;
	cd output;
	vcs -full64 -f filelist.f;

有时候由于打开的verdi占用了output这个文件夹中的文件,导致执行make comp的时候,rm -rf output这条执行出错,最终导致后面的代码都不会被执行。

make comp
rm: cannot remove 'test/verdiLog': Directory not empyt

一般情况,我们都会关闭verdi打开的波形,释放对这个文件夹的占用,再执行make comp。但是更多时候,我们的verdi拉出了debug的波形,不希望被关掉,而且反复打开verdi也比较麻烦。
其实,在comp函数中,前面rm和mkdir这两条命令哪怕执行出错了,也不影响正常的仿真。所以,可以在这两条命令前面加上横杠“-”,即使这两条执行出错,makefile的执行也不会中断,不影响后续正常的仿真。

comp:
	-rm -rf output;
	-mkdir output;
	cd output;
	vcs -full64 -f filelist.f;

总结

通常make执行的命令出错就立刻终止,不再执行后续命令,但是如果命令前面加上“-”,即使这条命令出错,makefile也会继续执行后续命令。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值