如果给定其他配置文件,则rebar不会自动重建文件。因此,我尝试在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
希望的意图很明显:当我使用需要特定配置文件的目标时,请检查上次是否使用了相同的文件;运行clean并记录我们现在使用的配置。
clean
但这不起作用,并且文件会不断重新编译:
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
尽管config.tmp包含“ normal”:
aromanov@alexey-desktop:~/workspace/gmcontroller/lib/sqlite3$ LAST_CONFIG=$(cat config.tmp); echo $LAST_CONFIG normal
我想念什么?
shell在定义变量时,您缺少用于实际调用外部程序的部分。
shell
LAST_CONFIG:=$(shell cat config.tmp)