summaryrefslogtreecommitdiffstats
path: root/Makefile
blob: cef8c52d7976cf29cd36c2a4744f74c2a02a93d9 (plain) (blame)
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
.POSIX:

CONFIGFILE = config.mk
include $(CONFIGFILE)

OS = linux
# Linux:   linux
# Mac OS:  macos
# Windows: windows
include mk/$(OS).mk


LIB_MAJOR = 1
LIB_MINOR = 0
LIB_VERSION = $(LIB_MAJOR).$(LIB_MINOR)
LIB_NAME = log


OBJ =\
	liblog_alert.o\
	liblog_alert_cork.o\
	liblog_apply_env_mask.o\
	liblog_clear_mask.o\
	liblog_critical.o\
	liblog_critical_cork.o\
	liblog_debug.o\
	liblog_debug_cork.o\
	liblog_destroy_context.o\
	liblog_destroy_output.o\
	liblog_dump_backtrace.o\
	liblog_dump_backtrace_cork.o\
	liblog_emergency.o\
	liblog_emergency_cork.o\
	liblog_error.o\
	liblog_error_cork.o\
	liblog_flush__.o\
	liblog_info.o\
	liblog_info_cork.o\
	liblog_init_context.o\
	liblog_log.o\
	liblog_log_cork.o\
	liblog_log_no_backtrace.o\
	liblog_log_no_backtrace_cork.o\
	liblog_logmask__.o\
	liblog_mask_level.o\
	liblog_mask_range.o\
	liblog_mask_verbose.o\
	liblog_notice.o\
	liblog_notice_cork.o\
	liblog_trace.o\
	liblog_trace__.o\
	liblog_trace_cork.o\
	liblog_uncork.o\
	liblog_unmask_level.o\
	liblog_unmask_range.o\
	liblog_unmask_verbose.o\
	liblog_use_fd.o\
	liblog_use_fd_for_range.o\
	liblog_use_file.o\
	liblog_use_file_for_range.o\
	liblog_use_output.o\
	liblog_use_stderr.o\
	liblog_use_stderr_for_range.o\
	liblog_use_stream.o\
	liblog_use_stream_for_range.o\
	liblog_use_syslog.o\
	liblog_use_syslog_for_range.o\
	liblog_valert.o\
	liblog_valert_cork.o\
	liblog_vcritical.o\
	liblog_vcritical_cork.o\
	liblog_vdebug.o\
	liblog_vdebug_cork.o\
	liblog_vemergency.o\
	liblog_vemergency_cork.o\
	liblog_verror.o\
	liblog_verror_cork.o\
	liblog_vinfo.o\
	liblog_vinfo_cork.o\
	liblog_vlog.o\
	liblog_vlog_cork.o\
	liblog_vlog_no_backtrace.o\
	liblog_vlog_no_backtrace_cork.o\
	liblog_vnotice.o\
	liblog_vnotice_cork.o\
	liblog_vtrace.o\
	liblog_vtrace_cork.o\
	liblog_vwarning.o\
	liblog_vwarning_cork.o\
	liblog_vxlog.o\
	liblog_warning.o\
	liblog_warning_cork.o\
	liblog_whence__.o\
	liblog_xlog.o

HDR =\
	liblog.h\
	common.h

LOBJ = $(OBJ:.o=.lo)
TOBJ = $(OBJ:.o=.to)
TEST = $(OBJ:.o=.test)


all: liblog.a liblog.$(LIBEXT) $(TEST)
$(OBJ): $(HDR)
$(LOBJ): $(HDR)
$(TOBJ): $(HDR)
$(TEST): testhelp.o liblog.a
liblog_alert_cork.to liblog_critical_cork.to liblog_debug_cork.to liblog_emergency_cork.to liblog_error_cork.to liblog_notice_cork.to liblog_trace_cork.to liblog_warning_cork.to: test-level_cork.c
liblog_valert_cork.to liblog_vcritical_cork.to liblog_vdebug_cork.to liblog_vemergency_cork.to liblog_verror_cork.to liblog_vnotice_cork.to liblog_vtrace_cork.to liblog_vwarning_cork.to: test-vlevel_cork.c
liblog_alert.to liblog_critical.to liblog_debug.to liblog_emergency.to liblog_error.to liblog_notice.to liblog_trace.to liblog_warning.to: test-level.c
liblog_valert.to liblog_vcritical.to liblog_vdebug.to liblog_vemergency.to liblog_verror.to liblog_vnotice.to liblog_vtrace.to liblog_vwarning.to: test-vlevel.c
liblog_alert_cork.to liblog_valert_cork.to liblog_alert.to liblog_valert.to: test-alert.h
liblog_critical_cork.to liblog_vcritical_cork.to liblog_critical.to liblog_vcritical.to: test-critical.h
liblog_debug_cork.to liblog_vdebug_cork.to liblog_debug.to liblog_vdebug.to: test-debug.h
liblog_emergency_cork.to liblog_vemergency_cork.to liblog_emergency.to liblog_vemergency.to: test-emergency.h
liblog_error_cork.to liblog_verror_cork.to liblog_error.to liblog_verror.to: test-error.h
liblog_notice_cork.to liblog_vnotice_cork.to liblog_notice.to liblog_vnotice.to: test-notice.h
liblog_trace_cork.to liblog_vtrace_cork.to liblog_trace.to liblog_vtrace.to: test-trace.h
liblog_warning_cork.to liblog_vwarning_cork.to liblog_warning.to liblog_vwarning.to: test-warning.h

.c.o:
	$(CC) -c -o $@ $< $(CFLAGS) $(CPPFLAGS)

.c.lo:
	$(CC) -fPIC -c -o $@ $< $(CFLAGS) $(CPPFLAGS)

.c.to:
	$(CC) -c -o $@ $< $(CFLAGS) $(CPPFLAGS) -DTEST

.to.test:
	$(CC) -o $@ $< testhelp.o liblog.a $(LDFLAGS)

liblog.a: $(OBJ)
	@rm -f -- $@
	$(AR) rc $@ $(OBJ)
	$(AR) ts $@ > /dev/null

liblog.$(LIBEXT): $(LOBJ)
	$(CC) $(LIBFLAGS) -o $@ $(LOBJ) $(LDFLAGS)

check: $(TEST)
	@set -e;\
	status=0;\
	for t in $(TEST); do\
		if test -n "$(CHECK_PREFIX)"; then\
			printf '%s\n' "$(CHECK_PREFIX) ./$$t";\
		else\
			printf '%s\n' "./$$t";\
		fi;\
		if ! $(CHECK_PREFIX) ./$$t; then\
			status=1;\
		fi;\
	done;\
	exit $$status

install: liblog.a liblog.$(LIBEXT)
	mkdir -p -- "$(DESTDIR)$(PREFIX)/lib"
	mkdir -p -- "$(DESTDIR)$(PREFIX)/include"
	cp -- liblog.a "$(DESTDIR)$(PREFIX)/lib/"
	cp -- liblog.$(LIBEXT) "$(DESTDIR)$(PREFIX)/lib/liblog.$(LIBMINOREXT)"
	$(FIX_INSTALL_NAME) "$(DESTDIR)$(PREFIX)/lib/liblog.$(LIBMINOREXT)"
	ln -sf -- liblog.$(LIBMINOREXT) "$(DESTDIR)$(PREFIX)/lib/liblog.$(LIBMAJOREXT)"
	ln -sf -- liblog.$(LIBMAJOREXT) "$(DESTDIR)$(PREFIX)/lib/liblog.$(LIBEXT)"
	cp -- liblog.h "$(DESTDIR)$(PREFIX)/include/"

uninstall:
	-rm -f -- "$(DESTDIR)$(PREFIX)/lib/liblog.a"
	-rm -f -- "$(DESTDIR)$(PREFIX)/lib/liblog.$(LIBMAJOREXT)"
	-rm -f -- "$(DESTDIR)$(PREFIX)/lib/liblog.$(LIBMINOREXT)"
	-rm -f -- "$(DESTDIR)$(PREFIX)/lib/liblog.$(LIBEXT)"
	-rm -f -- "$(DESTDIR)$(PREFIX)/include/liblog.h"

clean:
	-rm -f -- *.o *.a *.lo *.su *.so *.so.* *.dll *.dylib *.to *.test
	-rm -f -- *.gch *.gcov *.gcno *.gcda *.$(LIBEXT)

.SUFFIXES:
.SUFFIXES: .lo .o .c .to .test

.PHONY: all check install uninstall clean