forked from esl/MongooseIM
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
81 lines (60 loc) · 2.32 KB
/
Makefile
File metadata and controls
81 lines (60 loc) · 2.32 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
.PHONY: rel
LOG=$(subst TARGET,$@,TARGET.log 2>&1 || (cat TARGET.log; exit 1))
SILENCE_COVER = | grep -v "logs.*\\.coverdata"
SILENCE_COVER += | grep -v "Analysis includes data from imported files"
SILENCE_COVER += | grep -v "WARNING: Deleting data for module"
LOG_SILENCE_COVER=$(subst TARGET,$@,TARGET.log 2>&1 || (cat TARGET.log $(SILENCE_COVER); exit 1))
EJABBERD_DIR = apps/ejabberd
XEP_TOOL = tools/xep_tool
EJD_EBIN = $(EJABBERD_DIR)/ebin
DEVNODES = mim1 mim2 mim3 fed1
# Top-level targets aka user interface
all: rel
dev: $(DEVNODES)
clean:
-rm -rf _build
-rm rel/configure.vars.config
-rm rel/vars.config
ct:
@(if [ "$(SUITE)" ]; then ./rebar3 ct --dir apps/ejabberd/test --suite $(SUITE) ;\
else ./rebar3 ct ; fi) > $(LOG_SILENCE_COVER)
rel: certs configure.out rel/vars.config
. ./configure.out && ./rebar3 as prod release
shell: certs etc/ejabberd.cfg
./rebar3 shell
# Top-level targets' dependency chain
rock:
@if [ "$(FILE)" ]; then elvis rock $(FILE);\
elif [ "$(BRANCH)" ]; then tools/rock_changed.sh $(BRANCH); \
else tools/rock_changed.sh; fi
rel/vars.config: rel/vars.config.in rel/configure.vars.config
cat $^ > $@
## Don't allow these files to go out of sync!
configure.out rel/configure.vars.config:
./tools/configure with-all
etc/ejabberd.cfg:
@mkdir -p $(@D)
tools/generate_cfg.es etc/ejabberd.cfg rel/files/ejabberd.cfg
devrel: $(DEVNODES)
$(DEVNODES): certs configure.out rel/vars.config
@echo "building $@"
(. ./configure.out && \
DEVNODE=true ./rebar3 as $@ release) > $(LOG_SILENCE_COVER)
certs: priv/ssl/fake_cert.pem priv/ssl/fake_server.pem priv/ssl/fake_dh_server.pem
priv/ssl/fake_cert.pem:
@mkdir -p $(@D)
openssl req \
-x509 -nodes -days 365 \
-subj '/C=PL/ST=ML/L=Krakow/CN=mongoose-im' \
-newkey rsa:2048 -keyout priv/ssl/fake_key.pem -out priv/ssl/fake_cert.pem
priv/ssl/fake_server.pem: priv/ssl/fake_cert.pem
cat priv/ssl/fake_cert.pem priv/ssl/fake_key.pem > priv/ssl/fake_server.pem
priv/ssl/fake_dh_server.pem:
@mkdir -p $(@D)
openssl dhparam -outform PEM -out priv/ssl/fake_dh_server.pem 1024
xeplist: escript
escript $(XEP_TOOL)/xep_tool.escript markdown $(EJD_EBIN)
install: configure.out rel
@. ./configure.out && tools/install
cover_report: /tmp/mongoose_combined.coverdata
erl -noshell -pa _build/default/lib/*/ebin -eval 'ecoveralls:travis_ci("$?"), init:stop()' > $(LOG)