【问题标题】:Target for make gives "nothing to be done"make 的目标给出“无事可做”
【发布时间】:2013-11-04 08:09:29
【问题描述】:

我对“make”有疑问(哦,太可怕了!)。

我们正在尝试将一些 COBOL 代码从 Windows 迁移到 Linux。编译器等来自 Micro Focus。在 Windows 下,代码是使用 Micro Focus Net Express 开发的。 Linux 具有 Micro Focus Server Express 作为等效项。这些程序是使用“make”脚本编译和链接的。

背景就这么多。

问题是“make”脚本不想在 Linux 下编译和链接可执行文件。目标如下所示:

# HP INIT-Daten laden
#
datLoad$O:   \
        $(UI)/defretrn.cpy \
        $(UI)/e12sy00s.cpy \
        $(UI)/e12sy005.cpy \
        $(UI)/e12sy006.cpy \
        $(UI)/e12sy010.cpy \
        $(UI)/e12sy013.cpy \
        $(UI)/e12sy050.cpy \
        $(UI)/e12db001.cpy \
        $(UI)/e12db050.cpy \
        $(UI)/evlg.cpy \
        $(UI)/deffehl.cpy \
        datLoad.xcbl $(FRC)
#       @echo "dollar-O is \"$O\" in $@"


datLoad$X:  $(LIBDSQL) datLoad$O \
        $(LP)/evlg$O $(LP)/alock$O
    $(LCOB) -o $(@:$X=) -e $(@:$X=) $(LCOBFLAGS) \
        -d e12db001 -d e12db003 -d e12db012 \
        -d e12sy005 -d e12sy006 -d e12sy009 \
        -d e12sy010 -d e12sy012 -d e12sy013 \
        -d e12sy050 \
        -I EvLgSetCategory $(LP)/evlg$O \
        -I ALckSetDebug $(LP)/alock$O \
        $(LIBEXEEXT) "$(LIBXSQL)"
    if [ -f $B/$@ -a ! -w $B/$@ ] ; then rm -f $B/$@ ; fi
    cp $@ $B

将其放入上下文中,$0=".o"(即目标文件扩展名)。 $(LCOB) 是链接命令。 $X=".exe" (一个可执行文件......忘记扩展名,我们会在适当的时候修复它)。所有其他内容都与路径有关 ==> 与手头的问题无关,是的,它们都已经过检查和验证。

最终,我试图让“make”来解析一个名为“datLoad.o”的目标。

第二个“make”脚本包含以下内容:

COBFLAGS    = -cx # create object file
GNTFLAGS    =   -ug # create .gnt file
SOFLAGS     =   -z # create 
LCOB        = cob
...
.cbl$O:
    $(CCOB) $(COBFLAGS) $*.cbl, $*$O, NUL, NUL
    if [ -f $(LP)/$*$O -a ! -w $(LP)/$*$O ] ; then rm -f $(LP)/$*$O ; fi
    cp $*$O $(LP)

相关部分是解析为“.cbl.o:”的目标。是的,这是速记版本,我不太喜欢它,但我没有写这个脚本。我确信这确实意味着 *.o:*.cbl 和脚本中的其他类似结构确实可以正常工作。

使用简单的“make”我得到一个链接错误:

> In function `cbi_entry_point': (.data+0x384): undefined reference to
> `datLoad' /tmp/cobwZipkt/%cob0.o: In function `main': (.text+0x28):
> undefined reference to `datLoad' make: *** [datLoad.exe] Error 1

这意味着没有创建 datLoad.o。如果我确实使用以下命令明确创建它:

 cob -cx datload

然后“make”仍然给出与上面相同的错误。诡异的!但是,我真正无法理解的是当目标存在时我从“make datLoad.o”得到的响应:

make: Nothing to be done for `datLoad.o'.

我假设(上帝帮助我)目标“datLoad.o”会尝试创建所需的目标文件,如果该文件尚不存在。我要疯了吗?

抱歉,如果这看起来有点晦涩难懂,我不知道如何更好地表达它。如果有人知道可能会发生什么,我将不胜感激......

【问题讨论】:

  • 您联系过 Micro Focus 支持吗? www.microfocus.com
  • 由于您使用的是后缀规则格式,我假设您使用了.SUFFIXES: .cbl .o 来确保.cbl 是一个已知的后缀。我建议您运行 make -p 并检查输出以验证您期望的规则是否存在,$O 变量设置得足够早,因此它具有正确的值等。您也可以运行 make -d 并检查输出以了解采取哪些步骤来确定目标是否已过时。
  • @Bill Woodger:问题不在于 Micro Focus。我只是提供了一些背景信息。
  • 当时的想法是,Micro Focus 已经拥有走这条路的客户,并且可能有一个需要注意的事项清单。无论如何,你在这里很幸运。

标签: linux makefile cobol microfocus


【解决方案1】:

谢谢疯狂科学家。你的提示是正确的。

包含的 .mk 包含一个 .SUFFIXES 规则。问题是 $O 没有被一致地使用。对于 Windows,$O 最初设置为“.obj”。在 Linux 下它是“.o”。但是,.SUFFIXES 规则将“.obj”硬编码到其中,因此“.o”目标当然没有被识别。我用 $O 变量替换了硬编码的后缀,它现在可以工作了。

阿奇姆

【讨论】:

    猜你喜欢
    • 2012-01-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-04-10
    相关资源
    最近更新 更多