@@ -11,13 +11,16 @@ SOURCE_DIR=src
1111EBIN_DIR =ebin
1212INCLUDE_DIR =include
1313SOURCES =$(wildcard $(SOURCE_DIR ) /* .erl)
14- BEAM_TARGETS =$(EBIN_DIR ) /rabbit_framing.beam $(patsubst $(SOURCE_DIR ) /% .erl, $(EBIN_DIR ) /% .beam,$(SOURCES ) )
14+ BEAM_TARGETS =$(EBIN_DIR ) /rabbit_framing.beam $(patsubst $(SOURCE_DIR ) /% .erl, $(EBIN_DIR ) /% .beam, $(SOURCES ) )
1515TARGETS =$(EBIN_DIR ) /rabbit.app $(BEAM_TARGETS )
1616WEB_URL =http://stage.rabbitmq.com/
1717MANPAGES =$(patsubst % .pod, % .gz, $(wildcard docs/* .[0-9].pod) )
1818
1919PYTHON =python
2020
21+ BASIC_PLT =basic.plt
22+ RABBIT_PLT =rabbit.plt
23+
2124ifndef USE_SPECS
2225# our type specs rely on features / bug fixes in dialyzer that are
2326# only available in R13B upwards (R13B is eshell 5.7.1)
@@ -39,6 +42,8 @@ AMQP_SPEC_JSON_PATH=$(AMQP_CODEGEN_DIR)/amqp-0.8.json
3942
4043ERL_CALL =erl_call -sname $(RABBITMQ_NODENAME ) -e
4144
45+ ERL_EBIN =erl -noinput -pa $(EBIN_DIR )
46+
4247all : $(TARGETS )
4348
4449$(EBIN_DIR ) /rabbit.app : $(EBIN_DIR ) /rabbit_app.in $(BEAM_TARGETS ) generate_app
@@ -57,17 +62,32 @@ $(INCLUDE_DIR)/rabbit_framing.hrl: codegen.py $(AMQP_CODEGEN_DIR)/amqp_codegen.p
5762$(SOURCE_DIR ) /rabbit_framing.erl : codegen.py $(AMQP_CODEGEN_DIR ) /amqp_codegen.py $(AMQP_SPEC_JSON_PATH )
5863 $(PYTHON ) codegen.py body $(AMQP_SPEC_JSON_PATH ) $@
5964
60- $(EBIN_DIR ) /rabbit.boot $(EBIN_DIR ) /rabbit.script : $(EBIN_DIR ) /rabbit.app $(EBIN_DIR ) /rabbit.rel $(TARGETS )
61- erl -noshell -eval ' systools:make_script("ebin/rabbit", [{path, ["ebin"]}]), halt().'
65+ dialyze : $(BEAM_TARGETS ) $(BASIC_PLT )
66+ $(ERL_EBIN ) -eval \
67+ " rabbit_dialyzer:halt_with_code(rabbit_dialyzer:dialyze_files(\" $( BASIC_PLT) \" , \" $( BEAM_TARGETS) \" ))."
68+
69+ # rabbit.plt is used by rabbitmq-erlang-client's dialyze make target
70+ create-plt : $(RABBIT_PLT )
6271
63- dialyze : $(BEAM_TARGETS )
64- dialyzer -c $?
72+ $(RABBIT_PLT ) : $(BEAM_TARGETS ) $(BASIC_PLT )
73+ cp $(BASIC_PLT ) $@
74+ $(ERL_EBIN ) -eval \
75+ " rabbit_dialyzer:halt_with_code(rabbit_dialyzer:add_to_plt(\" $@ \" , \" $( BEAM_TARGETS) \" ))."
76+
77+ $(BASIC_PLT ) : $(BEAM_TARGETS )
78+ if [ -f $@ ]; then \
79+ touch $@ ; \
80+ else \
81+ $(ERL_EBIN ) -eval \
82+ " rabbit_dialyzer:halt_with_code(rabbit_dialyzer:create_basic_plt(\" $@ \" ))." ; \
83+ fi
6584
6685clean :
6786 rm -f $(EBIN_DIR ) /* .beam
68- rm -f $(EBIN_DIR ) /rabbit.app $(EBIN_DIR ) /rabbit.boot $(EBIN_DIR ) /rabbit.script
87+ rm -f $(EBIN_DIR ) /rabbit.app $(EBIN_DIR ) /rabbit.boot $(EBIN_DIR ) /rabbit.script $( EBIN_DIR ) /rabbit.rel
6988 rm -f $(INCLUDE_DIR ) /rabbit_framing.hrl $(SOURCE_DIR ) /rabbit_framing.erl codegen.pyc
7089 rm -f docs/* .[0-9].gz
90+ rm -f $(RABBIT_PLT )
7191
7292cleandb :
7393 rm -rf $(RABBITMQ_MNESIA_DIR ) /*
@@ -82,13 +102,14 @@ BASIC_SCRIPT_ENVIRONMENT_SETTINGS=\
82102
83103run : all
84104 $(BASIC_SCRIPT_ENVIRONMENT_SETTINGS ) \
85- RABBITMQ_NODE_ONLY =true \
86- RABBITMQ_SERVER_START_ARGS=" $( RABBITMQ_SERVER_START_ARGS) -s rabbit " \
105+ RABBITMQ_ALLOW_INPUT =true \
106+ RABBITMQ_SERVER_START_ARGS=" $( RABBITMQ_SERVER_START_ARGS) " \
87107 ./scripts/rabbitmq-server
88108
89109run-node : all
90110 $(BASIC_SCRIPT_ENVIRONMENT_SETTINGS ) \
91111 RABBITMQ_NODE_ONLY=true \
112+ RABBITMQ_ALLOW_INPUT=true \
92113 RABBITMQ_SERVER_START_ARGS=" $( RABBITMQ_SERVER_START_ARGS) " \
93114 ./scripts/rabbitmq-server
94115
@@ -173,7 +194,7 @@ install: all docs_all install_dirs
173194 cp -r ebin include LICENSE LICENSE-MPL-RabbitMQ INSTALL $(TARGET_DIR)
174195
175196 chmod 0755 scripts/*
176- for script in rabbitmq-env rabbitmq-server rabbitmqctl rabbitmq-multi rabbitmq-activate-plugins; do \
197+ for script in rabbitmq-env rabbitmq-server rabbitmqctl rabbitmq-multi rabbitmq-activate-plugins rabbitmq-deactivate-plugins ; do \
177198 cp scripts/$$script $(TARGET_DIR)/sbin; \
178199 [ -e $(SBIN_DIR)/$$script ] || ln -s $(SCRIPTS_REL_PATH)/$$script $(SBIN_DIR)/$$script; \
179200 done
0 commit comments