What does @: (at symbol colon) mean in a Makefile?

匿名 (未验证) 提交于 2019-12-03 09:02:45

问题:

What does the following do in a Makefile?

rule: $(deps)     @:

I can't seem to find this in the make manual.

回答1:

It means "don't echo this command on the output." So this rule is saying "execute the shell command : and don't echo the output.

Of course the shell command : is a no-op, so this is saying "do nothing, and don't tell."

Why?

The trick here is that you've got an obscure combination of two different syntaxes. The make(1) syntax is the use of an action starting with @, which is simply not to echo the command. So a rule like

always:        @echo this always happens

won't emit

   echo this always happens    this always happens

Now, the action part of a rule can be any shell command, including :. Bash help explains this as well as anywhere:

$ help : :: :     Null command.      No effect; the command does nothing.      Exit Status:     Always succeeds.


回答2:

For those curious about why you might do this, it is useful if you want to pretend like something was done, so that Make doesn't output "Nothing to be done for" your target.

One example is if you have a phony target that you always execute, and in it you have a bunch of conditionals in the command. You want to have at least something in case those conditions come up false and nothing gets done.

For example (from Linux's scripts/Makefile.clean):

__clean: $(subdir-ymn) ifneq ($(strip $(__clean-files)),)     +$(call cmd,clean) endif ifneq ($(strip $(__clean-dirs)),)     +$(call cmd,cleandir) endif ifneq ($(strip $(clean-rule)),)     +$(clean-rule) endif     @:


标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!