-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
206 lines (164 loc) · 5.63 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
# ===============================================================================
# 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
INSTALL_TARGETS := install-headers
# Build for distribution
.PHONY: distro
ifeq ($(STATICLINK),1)
distro: static
else
distro: shared
endif
distro: $(DOC_TARGETS)
# Shared libraries (versioned and unversioned)
.PHONY: shared
shared: $(LIB)/libxchange.so
# Legacy static libraries (locally built)
.PHONY: static
static: $(LIB)/libxchange.a
# Build libraries
.PHONY: libs
libs: shared static
# Build everything...
.PHONY: all
all: libs $(DOC_TARGETS) check
# Run regression tests
.PHONY: test
test: $(LIB)/libxchange.a
$(MAKE) -C test
# 'test" + 'analyze'
.PHONY: check
check: test analyze
# Static code analysis via Facebook's infer
.PHONY: infer
infer: clean
infer run -- $(MAKE) shared
# Remove intermediates
.PHONY: clean
clean:
rm -f $(OBJECTS) README-xchange.md gmon.out
$(MAKE) -C test clean
# Remove all generated files
.PHONY: distclean
distclean: clean
rm -f $(LIB)/libxchange.so* $(LIB)/libxchange.a
$(MAKE) -C test distclean
# ----------------------------------------------------------------------------
# The nitty-gritty stuff below
# ----------------------------------------------------------------------------
SOURCES = $(SRC)/xchange.c $(SRC)/xstruct.c $(SRC)/xlookup.c $(SRC)/xjson.c
# Generate a list of object (obj/*.o) files from the input sources
OBJECTS := $(subst .c,.o,$(subst $(SRC),$(OBJ),$(SOURCES)))
$(LIB)/libxchange.so: $(LIB)/libxchange.so.$(SO_VERSION)
# Shared library
$(LIB)/libxchange.so.$(SO_VERSION): $(SOURCES)
# Static library
$(LIB)/libxchange.a: $(OBJECTS)
README-xchange.md: README.md
LINE=`sed -n '/\# /{=;q;}' $<` && tail -n +$$((LINE+2)) $< > $@
dox: README-xchange.md
.INTERMEDIATE: Doxyfile.local
Doxyfile.local: Doxyfile Makefile
sed "s:resources/header.html::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-xchange.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)
libdir ?= $(exec_prefix)/lib
includedir ?= $(prefix)/include
datarootdir ?= $(prefix)/share
datadir ?= $(datarootdir)
mydatadir ?= $(datadir)/xchange
docdir ?= $(datarootdir)/doc/xchange
htmldir ?= $(docdir)/html
# Standard install commands
INSTALL_PROGRAM ?= install
INSTALL_DATA ?= install -m 644
.PHONY: install
install: install-libs 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)/* $(DESTDIR)$(libdir)/
else
@echo "WARNING! Skipping libs install: needs 'shared' and/or 'static'"
endif
.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 'libxchange.so' (linked to versioned)."
@echo " static Builds the static 'lib/libxchange.a' library."
@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