Buddy_Zhang1 发表于 2016-08-09 21:43

朋友帮忙分析一个 Makefile 的语句含义

请懂下面语句含义的朋友帮忙说明一下。谢谢

try-run = $(shell set -e;       \
    TMP="$(TMPOUT).$$$$.tmp";   \
    TMPO="$(TMPOUT).$$$$.o";    \
    if ($(1)) >/dev/null 2>&1;\
    then echo "$(2)";       \
    else echo "$(3)";       \
    fi;             \
    rm -f "$$TMP" "$$TMPO")

chengxta 发表于 2016-08-10 11:46

在makefile中执行shell脚本命令,测试$(1)命令执行情况,成功返回$(2),失败返回$(3);
shell set -e:一旦出现非零返回值,则立即退出shell脚本;
TMP="$(TMPOUT).$$$$.tmp";:定义临时文件,"$$$$"是随机编号;
if ($(1)) >/dev/null 2>&1;
then echo "$(2)";
else echo "$(3)";
fi;
测试命令,成功返回$(2),失败返回$(3)
>/dev/null 2>&1:标准输出和标准错误指向空设备,即不输出任何信息到终端;
rm -f "$$TMP" "$$TMPO":删除临时文件

try-run是内核makefile的一段宏定义,常被cc-option等引用,测试编译选项:
cc-option = $(call try-run,\
                $(CC) $(1) -c -x c /dev/null -o "$$TMP",$(1),$(2))

-c:只编译不链接;
-x c:指定c语言编译器;
用法:cflags-y += $(call cc-option,-march=winchip-c6,-march=i586)
测试编译选项"-march=winchip-c6",支持(命令执行成功)则使用"-march=winchip-c6",否则使用"-march=i586";

Buddy_Zhang1 发表于 2016-08-10 22:48

回复 2# chengxta


    朋友非常非常感谢。
页: [1]
查看完整版本: 朋友帮忙分析一个 Makefile 的语句含义