makefile实际上是在一个文件中用两种完全不同的“语言”编写的。
recipe(运行编译器,echo等的命令)是用shell脚本语法编写的。
不在recipe中的其余makefile是用makefile语法编写的。
为了使make能够区分recipe和不是recipe的东西,它使用了TAB字符。因此,
以TAB开头的行被假定为recipe的一部分,因此它们是shell脚本并传递给shell进行解析。
以空格开头的行不能成为recipe的一部分,它们必须是makefile语法,用空格。
ifneq
是makefile语法:它不能成为recipe的一部分,并且以空格开头。
结论:
1、在写makefile语法,非recipe的时候,缩进应该使用空格。
2、在写shell语法,recipe时,缩进使用TAB。因为实际上我们写的是希望shell执行的语句,所以使用的是shell syntax。而make识别recipe的方式就是。