Makefile依赖变量

时间:2016-07-28 10:34:13

标签: makefile gnu-make

我有一个简单的Makefile。当我不在依赖列表中使用变量时,它工作正常。否则会出现以下错误:

make: *** No rule to make target 'ext/configXML.o', needed by 'libledrgb-jni.so'.  Stop.

此外,当我做

    make print-LED-CFG-SRC
LED-CFG-SRC = ../led-cfg/src

因此,如果我明确为此文件添加规则,则设置正确的值:

ext/configXML.o: $(LED-CFG-SRC)/%.cc 
@echo 'Building file: $<'
@${CXX} $(CXXFLAGS) -c -o "$@" "$<"

看起来问题在于LED-CFG-SRC到源文件:

 make ext/configXML.o
make: *** No rule to make target '/configXML.cc', needed by 'ext/configXML.o'.  Stop.

但该文件存在:

   make list
ls -la ../led-cfg/src
total 340
drwxrwxr-x  2 gigi gigi  4096 lip 27 13:10 .
drwxrwxr-x 12 gigi gigi  4096 lip 28 10:08 ..
-rw-rw-r--  1 gigi gigi 11918 lip 28 09:54 configXML.cc
-rw-rw-r--  1 gigi gigi  2891 lip 27 13:17 configXML.h

这是源Makefile:

    EXTOBJS = ext/configXML.o ext/packet.o ext/tinyxml2.o ext/crypt.o ext/rozkaz.o
    LED-CFG-SRC := ../led-cfg/src/ 
    INCLUDES := -I$(LED-CFG-SRC)
    CXXFLAGS := $(INCLUDES)
    LIBRARY := libledrgb-jni.so

    CXXFLAGS := $(INCLUDES) -fPIC -std=c++14

    all: dirs $(LIBRARY)

    $(LIBRARY): $(OBJFILES) $(EXTOBJS)
        $(CXX) -shared -o $@ $^



    ext/%.o: $(LED-CFG-SRC)/%.cc 
        @echo 'Building file: $<'
        @${CXX} $(CXXFLAGS) -c -o "$@" "$<"


    clean:
        rm -rf $(EXTOBJS)

    list:
        ls -la $(LED-CFG-SRC)

    print-%  : ; @echo $* = $($*)


    .PHONY: clean dirs

我正在使用GNU Make 4.1

1 个答案:

答案 0 :(得分:1)

在黑暗中拍摄。至少在您发布的Makefile列表中,LED-CFG-SRC变量的定义中存在冗余的不需要的空格:

LED-CFG-SRC := ../led-cfg/src/<there-is-reduntant-whitespace-here>

这意味着,当稍后在规则定义中展开变量时,make会看到../led-cfg/src/ %.cc(两个字,$< = ../led-cfg/src/和{{1仅作为附加依赖项而不是预期的%.cc

您应该在编辑器中激活不可打印字符的显示,因为../led-cfg/src/%.cc在某些地方对于空白非常挑剔:有些人会选择自动剥离,但有些则保留。就像这里:make已经规定了make前面的空格,但它保留了最后一个空格。