2010-07-08 67 views
8

我在写一个通用的生成文件来构建静态库。它似乎运作良好,到目前为止,除了排队叫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?

注意:这可能已经在这里回答过了,但我至今无法将这些答案应用于我的具体问题!

回答

13
  • 你可以在sed中使用除正斜杠之外的任何东西作为分隔符。例如。 sed s~foo~bar~g
  • 您可以使用双引号"(至少在外壳)和变量仍然会扩大:echo "Hello $PLANET"
+2

我们该如何做一些像'sed s〜$ {PLANET}〜bar〜'的东西?由于某些原因,不能在Makefile中扩展 – 2015-09-12 01:38:06

5

如果你想扩展到一个文件的路径,您使用

sed -i "s/TO_REPLACE/$(subst, /,\/,${PATH_VARIABLE})/g" filename.txt 

如果您的变量PATH_VARIABLE样子的/ opt /路径/用户/家庭/等 它现在将膨胀到:

\ /opt\ /path\ /user\ /home\ /etc 

这应该允许sed正确插入'/'。

-Matt

+0

这很有帮助,谢谢! – 2016-08-09 20:34:17

+1

我认为这里有一个语法错误。而不是......'$(subst,/,\ /,$ {PATH_VARIABLE})',我认为它应该是'$(subst /,\ /,$ {PATH_VARIABLE})'。也就是说,在“subst”后面有一个额外的逗号。 – rdr 2017-01-17 15:45:19

+0

假设'PATH_VARIABLE'是一个Make变量,它应该是'$(subst /,\ /,$(PATH_VARIABLE))'吗? – CMCDragonkai 2017-01-21 11:42:02