-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
231 lines (186 loc) · 6.48 KB
/
Makefile
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
# ===============================================================================
# WARNING! You should leave this Makefile alone probably
# To configure the build, you can edit config.mk, or else you export the
# equivalent shell variables prior to invoking 'make' to adjust the
# build configuration.
# ===============================================================================
include config.mk
# ===============================================================================
# Specific build targets and recipes below...
# ===============================================================================
# The version of the shared .so libraries
SO_VERSION := 1
# Check if there is a doxygen we can run
ifndef DOXYGEN
DOXYGEN := $(shell which doxygen)
else
$(shell test -f $(DOXYGEN))
endif
# If there is doxygen, build the API documentation also by default
ifeq ($(.SHELLSTATUS),0)
DOC_TARGETS += local-dox
else
$(info WARNING! Doxygen is not available. Will skip 'dox' target)
endif
# Build for distribution
.PHONY: distro
distro: shared tools $(DOC_TARGETS)
# Build everything...
.PHONY: all
all: shared static tools $(DOC_TARGETS) check
# Shared libraries (versioned and unversioned)
.PHONY: shared
shared: $(LIB)/libsmax.so
# Legacy static libraries (locally built)
.PHONY: static
static: $(LIB)/libsmax.a
# Run regression tests
.PHONY: test
test: shared static
$(MAKE) -f test.mk
# Build benchmark program
.PHONY: benchmark
benchmark: shared static
$(MAKE) -f test.mk benchmark
# 'test' + 'analyze'
.PHONY: check
check: test analyze
# Static code analysis via Facebook's infer
.PHONY: infer
infer: clean
infer run -- $(MAKE) shared
.PHONY: tools
tools:
$(MAKE) -f tools.mk all
# Link tools against the static or shared libs
ifeq ($(STATICLINK),1)
tools: static
else
tools: shared
endif
# Remove intermediates
.PHONY: clean
clean:
rm -f $(OBJECTS) README-smax.md gmon.out
# Remove all generated files
.PHONY: distclean
distclean: clean
rm -f Doxyfile.local $(LIB)/libsmax.so* $(LIB)/libsmax.a
# ----------------------------------------------------------------------------
# The nitty-gritty stuff below
# ----------------------------------------------------------------------------
SOURCES = $(SRC)/smax.c $(SRC)/smax-easy.c $(SRC)/smax-lazy.c $(SRC)/smax-queue.c \
$(SRC)/smax-meta.c $(SRC)/smax-messages.c $(SRC)/smax-resilient.c $(SRC)/smax-util.c
# Generate a list of object (obj/*.o) files from the input sources
OBJECTS := $(subst $(SRC),$(OBJ),$(SOURCES))
OBJECTS := $(subst .c,.o,$(OBJECTS))
$(LIB)/libsmax.so: $(LIB)/libsmax.so.$(SO_VERSION)
# Shared library
$(LIB)/libsmax.so.$(SO_VERSION): $(SOURCES)
# Static library
$(LIB)/libsmax.a: $(OBJECTS)
README-smax.md: README.md
LINE=`sed -n '/\# /{=;q;}' $<` && tail -n +$$((LINE+2)) $< > $@
dox: README-smax.md
.INTERMEDIATE: Doxyfile.local
Doxyfile.local: Doxyfile Makefile
sed "s:resources/header.html::g" $< > $@
sed -i "s:^TAGFILES.*$$:TAGFILES = :g" $@
# Local documentation without specialized headers. The resulting HTML documents do not have
# Google Search or Analytics tracking info.
.PHONY: local-dox
local-dox: README-smax.md Doxyfile.local
doxygen Doxyfile.local
# Some standard GNU targets, that should always exist...
.PHONY: html
html: local-dox
.PHONY: dvi
dvi:
.PHONY: ps
ps:
.PHONY: pdf
pdf:
# Default values for install locations
# See https://www.gnu.org/prep/standards/html_node/Directory-Variables.html
prefix ?= /usr
exec_prefix ?= $(prefix)
bindir ?= $(exec_prefix)/bin
libdir ?= $(exec_prefix)/lib
includedir ?= $(prefix)/include
datarootdir ?= $(prefix)/share
datadir ?= $(datarootdir)
mydatadir ?= $(datadir)/smax-clib
mandir ?= $(datarootdir)/man
docdir ?= $(datarootdir)/doc/smax-clib
htmldir ?= $(docdir)/html
# Standard install commands
INSTALL_PROGRAM ?= install
INSTALL_DATA ?= install -m 644
.PHONY: install
install: install-libs install-tools install-man install-headers install-html
.PHONY: install-libs
install-libs:
ifneq ($(wildcard $(LIB)/*),)
@echo "installing libraries to $(DESTDIR)$(libdir)"
install -d $(DESTDIR)$(libdir)
$(INSTALL_PROGRAM) -D $(LIB)/lib*.so* $(DESTDIR)$(libdir)/
else
@echo "WARNING! Skipping libs install: needs 'shared' and/or 'static'"
endif
.PHONY: install-tools
install-tools:
ifneq ($(wildcard $(BIN)/*),)
@echo "installing executable(s) under $(DESTDIR)$(bindir)."
@install -d $(DESTDIR)$(bindir)
$(INSTALL_PROGRAM) -D $(BIN)/* $(DESTDIR)$(bindir)/
else
@echo "WARNING! Skipping tools install: needs 'tools'"
endif
.PHONY: install-man
install-man:
@echo "installing man pages under $(DESTDIR)$(mandir)."
@install -d $(DESTDIR)$(mandir)/man1
$(INSTALL_DATA) -D man/man1/* $(DESTDIR)$(mandir)/man1
.PHONY: install-headers
install-headers:
@echo "installing headers to $(DESTDIR)$(includedir)"
install -d $(DESTDIR)$(includedir)
$(INSTALL_DATA) -D include/* $(DESTDIR)$(includedir)/
.PHONY: install-html
install-html:
ifneq ($(wildcard apidoc/html/search/*),)
@echo "installing API documentation to $(DESTDIR)$(htmldir)"
install -d $(DESTDIR)$(htmldir)/search
$(INSTALL_DATA) -D apidoc/html/search/* $(DESTDIR)$(htmldir)/search/
$(INSTALL_DATA) -D apidoc/html/*.* $(DESTDIR)$(htmldir)/
@echo "installing Doxygen tag file to $(DESTDIR)$(docdir)"
install -d $(DESTDIR)$(docdir)
$(INSTALL_DATA) -D apidoc/*.tag $(DESTDIR)$(docdir)/
else
@echo "WARNING! Skipping apidoc install: needs doxygen and 'local-dox'"
endif
# Built-in help screen for `make help`
.PHONY: help
help:
@echo
@echo "Syntax: make [target]"
@echo
@echo "The following targets are available:"
@echo
@echo " shared Builds the shared 'libsmax.so' (linked to versioned)."
@echo " static Builds the static 'lib/libsmax.a' library."
@echo " tools Command line tools: 'bin/smaxValue' and 'bin/smaxWrite'."
@echo " local-dox Compiles local HTML API documentation using 'doxygen'."
@echo " analyze Performs static analysis with 'cppcheck'."
@echo " all All of the above."
@echo " distro shared libs and documentation (default target)."
@echo " install Install components (e.g. 'make prefix=<path> install')"
@echo " clean Removes intermediate products."
@echo " distclean Deletes all generated files."
@echo
# This Makefile depends on the config and build snipplets.
Makefile: config.mk build.mk
# ===============================================================================
# Generic targets and recipes below...
# ===============================================================================
include build.mk