我有一个简单的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
答案 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
前面的空格,但它保留了最后一个空格。