我在写一个通用的生成文件来构建静态库。它似乎运作良好,到目前为止,除了排队叫SED:在makefile中使用sed;如何逃避变量?
# Generic makefile to build a static library
ARCH = linux
CFLAGS = -O3 -Wall
SOURCES = src
BUILD_DIR = build/$(ARCH)
TARGET = $(BUILD_DIR)/libz.a
CFILES = $(foreach dir,$(SOURCES),$(wildcard $(dir)/*.c))
OBJECTS = $(addprefix $(BUILD_DIR)/,$(CFILES:.c=.o))
# Pull in the dependencies if they exist
# http://scottmcpeak.com/autodepend/autodepend.html
-include $(OBJECTS:.o=.dep)
default: create-dirs $(TARGET)
$(TARGET): $(OBJECTS)
$(AR) -rc $(TARGET) $^
$(BUILD_DIR)/%.o: %.c
$(CC) $(CFLAGS) -c $< -o [email protected]
$(CC) -M $(CFLAGS) $*.c > $(BUILD_DIR)/$*.tmp
sed s/.*:/$(BUILD_DIR)\\/$*.o:/ $(BUILD_DIR)/$*.tmp > $(BUILD_DIR)/$*.dep
@rm $(BUILD_DIR)/$*.tmp
.PHONY: create-dirs
create-dirs:
@for p in $(SOURCES); do mkdir -p $(BUILD_DIR)/$$p; done
.PHONY: clean
clean:
rm -fr $(BUILD_DIR)
sed的使用与其中对象实际上是完整路径替换目标文件的路径/名称。例如在本例中,'src/foo.o:'替换为'build/linux/src/foo.o:'。 $(BUILD_DIR)和$ *替换字符串在展开时都包含正斜杠 - 我如何将它们传递给sed?
注意:这可能已经在这里回答过了,但我至今无法将这些答案应用于我的具体问题!
我们该如何做一些像'sed s〜$ {PLANET}〜bar〜'的东西?由于某些原因,不能在Makefile中扩展 – 2015-09-12 01:38:06