-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
178 lines (142 loc) · 5.21 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
# ===============================================================================
# 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 libraries
.PHONY: libs
libs: shared static
# Build everything...
.PHONY: all
all: libs $(DOC_TARGETS) check
# Build for distribution
.PHONY: distro
distro: shared $(DOC_TARGETS)
# Shared libraries (versioned and unversioned)
.PHONY: shared
shared: $(LIB)/libxchange.so
# Legacy static libraries (locally built)
.PHONY: static
static: $(LIB)/libxchange.a
# Run regression tests
.PHONY: test
test: $(LIB)/libxchange.a
make -C test
# 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
# 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-apidoc
.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-apidoc
install-apidoc:
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 " check Performs static analysis with 'cppcheck'."
@echo " all All of the above."
@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