检查变量是否在makefile中定义

时间:2013-05-23 19:40:33

标签: makefile conditional environment-variables gnu-make

我有一个GNU Makefile(版本3.81),如下所示:

.PHONY: SPOneDot

SPOneDot:
    ifndef X
    X=0.05
    $$(info X undefined, changed to $X)
    endif
    ifndef Y
    Y=0.05
    $$(info Y undefined, changed to $Y)
    endif
    python ./Submit3DSP.py -f OneDot.qdt -x $(X) -y $(Y)

我使用以下命令行执行:make X=0.1 Y=0.1 SPOneDot但我得到以下结果:

ifndef X
make: ifndef: Command not found
make: *** [SPOneDot] Error 127

我查看了makefile documentation并看到了others use it。任何帮助都表示赞赏,这可能是愚蠢的。

2 个答案:

答案 0 :(得分:20)

您的make指令很可能不得缩进,而是从第一列开始。 我还怀疑你想要.if(...)或类似的,而不是普通的ifdef。如果不知道你使用的是make实现,很难说清楚。

在GNU make中,使用条件部分,例如像这样

ifeq ($(CC),gcc)
        $(CC) -o foo $(objects) $(libs_for_gcc)
else
        $(CC) -o foo $(objects) $(normal_libs)
endif

GNU make manual包含所有详细信息。

如果你真的想测试环境变量(而不是生成变量),那么只需在命令中执行此操作:

SPOneDot:
    if test -z "$$X"; then X=0.05; echo "X undefined, changed to $$X"; fi; \
    if test -z "$$Y"; then Y=0.05; echo "Y undefined, changed to $$Y"; fi; \
    python ./Submit3DSP.py -f OneDot.qdt -x $$X -y $$Y

请注意,$$作为单个$传递给shell,并且所有内容都必须是shell的单个命令,因此是分号和反斜杠/换行符。

答案 1 :(得分:4)

如果该行以制表符开头,则会将其视为规则配方的一部分。在条件指令行的开头允许并忽略多余的空格,但不允许使用制表符。