Makefile中调用shell常见问题

简单记录这这几天写程序Makefile.am文件遇到的两个问题,以后有遇到再补充

1. 调用的shell语句需要使用shell变量

    在makefile文件里变量名用$符号来标识,形如$(var)或者${var},当变量名为一个字符时,也可以写为$v,当我们要使用的shell要使用shell变量时,要用$$来标识,

如shell 命令为:

  cat /etc/redhat_release |awk '{print $2}'

在makefile里的写法则为:

 $(shell cat /etc/redhat_release |awk '{print $$2}')

2. 当调用的shell命令中有小括号字符时

shell命令如:

cat /etc/redhat-release | awk -F '(' '{print $1}'

在Makefile里的写法应为:

${shell cat /etc/redhat-release | awk -F '(' '{print $$1}'}

具体原因不清楚,没有找到相关的资料,如果仍按之前的写法则出现如下错误:

Makefile:2: *** unterminated call to function `shell': missing `)'.  Stop.

你可能感兴趣的:(学习笔记)