3 @@ -2,8 +2,12 @@ LIBS ?= -lpcap -lstdc++
4 RELEASEFLAGS ?= -O3 -Wall
5 #CXXFLAGS ?= --std=c++0x
7 +# check if libc provides BSD's strlcpy
8 +ifeq ($(shell $(CXX) $(CXXFLAGS) -D_BSD_SOURCE $(LDFLAGS) $(DEFS) -o /dev/null \
9 + make-checks/strlcpy.cpp 2>/dev/null; echo $$?),0)
10 + BSDSTR_DEFS := -D_BSD_SOURCE -DUSE_LIBC_STRLCPY
11 # auto-detect if bsd/strings.h is available
12 -ifeq ($(shell $(CXX) $(CXXFLAGS) $(LDFLAGS) $(DEFS) -E -o /dev/null \
13 +else ifeq ($(shell $(CXX) $(CXXFLAGS) $(LDFLAGS) $(DEFS) -E -o /dev/null \
14 make-checks/libbsd.cpp 2>/dev/null; echo $$?),0)
15 BSDSTR_DEFS := -DUSE_BSD_STRING_H
17 --- a/pcapsipdump_lib.h
18 +++ b/pcapsipdump_lib.h
21 #ifdef USE_BSD_STRING_H
22 #include <bsd/string.h>
24 + #elif !defined(USE_LIBC_STRLCPY)
25 #define strlcpy strncpy
28 --- a/make-checks/all.mk
29 +++ b/make-checks/all.mk
31 -make-checks/all: make-checks/cxx make-checks/libpcap make-checks/libbsd
32 +make-checks/all: make-checks/cxx make-checks/libpcap make-checks/strlcpy make-checks/libbsd
33 @touch make-checks/all
36 - rm -f make-checks/all make-checks/cxx make-checks/libpcap make-checks/libbsd
37 + rm -f make-checks/all make-checks/cxx make-checks/libpcap make-checks/strlcpy make-checks/libbsd
38 --- a/make-checks/libbsd.mk
39 +++ b/make-checks/libbsd.mk
40 @@ -2,5 +2,5 @@ CHECK_LIBBSD = $(CXX) $(CXXFLAGS) $(LDFL
43 @$(CHECK_LIBBSD) || (\
44 - echo "*** notice: recommended library not found: libbsd"; \
45 + echo "*** notice: library not found: libbsd"; \
48 +++ b/make-checks/strlcpy.cpp
51 +int main(int argc, char **argv) {
53 + strlcpy(dst, "test", sizeof(dst));
57 +++ b/make-checks/strlcpy.mk
59 +CHECK_STRLCPY = $(CXX) $(CXXFLAGS) -D_BSD_SOURCE $(LDFLAGS) make-checks/strlcpy.cpp -o make-checks/strlcpy 2>/dev/null
62 + @$(CHECK_STRLCPY) || (\
63 + echo "*** notice: your libc doesn't provide strlcpy()"; \