给定不同的configuration文件时, rebar不会自动重build文件。 所以,我试图在Makefile级别上做到这一点:
REBAR=./rebar REBAR_DEBUG=$(REBAR) -C rebar.debug.config REBAR_COMPILE=$(REBAR) get-deps compile LAST_CONFIG:=$(cat config.tmp) PLT=dialyzer/sqlite3.plt all: config_normal compile compile: $(REBAR_COMPILE) test: $(REBAR_COMPILE) eunit clean: -rm -rf deps ebin priv doc/* .eunit c_src/*.o docs: $(REBAR_COMPILE) doc static: config_debug $(REBAR_DEBUG) get-deps compile ifeq ($(wildcard $(PLT)),) dialyzer --build_plt --apps kernel stdlib erts --output_plt $(PLT) else dialyzer --plt $(PLT) -r ebin endif cross_compile: config_cross $(REBAR_COMPILE) -C rebar.cross_compile.config valgrind: clean $(REBAR_DEBUG) get-deps compile valgrind --tool=memcheck --leak-check=yes --num-callers=20 ./test.sh ifeq ($(LAST_CONFIG),normal) config_normal: echo "$(LAST_CONFIG) == normal" else config_normal: clean echo "$(LAST_CONFIG) != normal" rm -f config.tmp echo "normal" > config.tmp endif ifeq ($(LAST_CONFIG),debug) config_debug: ; else config_debug: clean rm -f config.tmp echo "debug" > config.tmp endif ifeq ($(LAST_CONFIG),cross) config_cross: ; else config_cross: clean rm -f config.tmp echo "cross" > config.tmp endif .PHONY: all compile test clean docs static valgrind config_normal config_debug config_cross
目的是显而易见的:当我使用一个需要某个configuration文件的目标时,检查上次是否使用了同一个文件; 运行clean
并logging我们现在使用的configuration。
但它不起作用,文件不断重新编译:
aromanov@alexey-desktop:~/workspace/gmcontroller/lib/sqlite3$ make rm -rf deps ebin priv doc/* .eunit c_src/*.o echo " != normal" != normal rm -f config.tmp echo "normal" > config.tmp ./rebar get-deps compile ==> sqlite3 (get-deps) ==> sqlite3 (compile) Compiled src/sqlite3_lib.erl Compiled src/sqlite3.erl Compiling c_src/sqlite3_drv.c
尽pipeconfig.tmp包含“normal”:
aromanov@alexey-desktop:~/workspace/gmcontroller/lib/sqlite3$ LAST_CONFIG=$(cat config.tmp); echo $LAST_CONFIG normal
我错过了什么?
在定义变量时,为了实际调用外部程序,您错过了需要使用shell
地方。
LAST_CONFIG:=$(shell cat config.tmp)
您也可以使用shell赋值运算符
LAST_CONFIG != cat config.tmp
§如何使读取一个Makefile
例