libpcap: build with cmake
The main motivation is to drop and stop maintaining
"100-debian_shared_lib.patch".  It lacks the logic to include custom
implementation of several functions like pcap_strlcpy() which can cause
build failures when glibc is used [2]
CAN and CAN-USB support related symbols are now handled by general linux
support, see [1]
"-ffunction-sections -fdata-sections" were removed as they should help
much for shared libraries
Size comparison before and after the change
  -rw-r--r-- 1 yunion yunion 238042 Oct 18 11:42 ipkg-x86_64/libpcap/usr/lib/libpcap.so.1
  lrwxrwxrwx 1 yunion yunion     16 Oct 18 13:03 ipkg-x86_64/libpcap/usr/lib/libpcap.so.1 -> libpcap.so.1.9.1
  -rwxr-xr-x 1 yunion yunion 229867 Oct 18 13:03 ipkg-x86_64/libpcap/usr/lib/libpcap.so.1.9.1
[1] On Linux, handle all CAN captures with pcap-linux.c, in cooked mode,
    93ca5ff703
[2] https://github.com/openwrt/packages/issues/10270
Signed-off-by: Yousong Zhou <yszhou4tech@gmail.com>
			
			
This commit is contained in:
		@@ -9,22 +9,23 @@ include $(TOPDIR)/rules.mk
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
PKG_NAME:=libpcap
 | 
					PKG_NAME:=libpcap
 | 
				
			||||||
PKG_VERSION:=1.9.1
 | 
					PKG_VERSION:=1.9.1
 | 
				
			||||||
PKG_RELEASE:=1
 | 
					PKG_RELEASE:=2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
 | 
					PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
 | 
				
			||||||
PKG_SOURCE_URL:=http://www.us.tcpdump.org/release/ \
 | 
					PKG_SOURCE_URL:=http://www.us.tcpdump.org/release/ \
 | 
				
			||||||
        http://www.tcpdump.org/release/
 | 
					        http://www.tcpdump.org/release/
 | 
				
			||||||
PKG_HASH:=635237637c5b619bcceba91900666b64d56ecb7be63f298f601ec786ce087094
 | 
					PKG_HASH:=635237637c5b619bcceba91900666b64d56ecb7be63f298f601ec786ce087094
 | 
				
			||||||
PKG_FIXUP:=patch-libtool
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
PKG_MAINTAINER:=Felix Fietkau <nbd@nbd.name>
 | 
					PKG_MAINTAINER:=Felix Fietkau <nbd@nbd.name>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
PKG_INSTALL:=1
 | 
					CMAKE_INSTALL:=1
 | 
				
			||||||
PKG_BUILD_PARALLEL:=1
 | 
					PKG_BUILD_PARALLEL:=1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
PKG_LICENSE:=BSD-3-Clause
 | 
					PKG_LICENSE:=BSD-3-Clause
 | 
				
			||||||
 | 
					PKG_LICENSE_FILES:=LICENSE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
include $(INCLUDE_DIR)/package.mk
 | 
					include $(INCLUDE_DIR)/package.mk
 | 
				
			||||||
include $(INCLUDE_DIR)/kernel.mk
 | 
					include $(INCLUDE_DIR)/cmake.mk
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define Package/libpcap
 | 
					define Package/libpcap
 | 
				
			||||||
  SECTION:=libs
 | 
					  SECTION:=libs
 | 
				
			||||||
@@ -44,55 +45,30 @@ define Package/libpcap/config
 | 
				
			|||||||
	source "$(SOURCE)/Config.in"
 | 
						source "$(SOURCE)/Config.in"
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
TARGET_CFLAGS += \
 | 
					CMAKE_OPTIONS += \
 | 
				
			||||||
	-ffunction-sections \
 | 
						-DBUILD_SHARED_LIBS=ON \
 | 
				
			||||||
	-fdata-sections
 | 
						-DBUILD_WITH_LIBNL=OFF \
 | 
				
			||||||
 | 
					
 | 
				
			||||||
CONFIGURE_VARS += \
 | 
					# grep 'option(DISABLE_' CMakeLists.txt | cut -f2 -d'(' | cut -f1 -d' ' | sort --unique
 | 
				
			||||||
	ac_cv_linux_vers=$(LINUX_VERSION) \
 | 
					CMAKE_OPTIONS += \
 | 
				
			||||||
	ac_cv_header_libusb_1_0_libusb_h=no
 | 
						-DDISABLE_DAG=ON \
 | 
				
			||||||
 | 
						-DDISABLE_DBUS=ON \
 | 
				
			||||||
 | 
						-DDISABLE_NETMAP=ON \
 | 
				
			||||||
 | 
						-DDISABLE_RDMA=ON \
 | 
				
			||||||
 | 
						-DDISABLE_SEPTEL=ON \
 | 
				
			||||||
 | 
						-DDISABLE_SNF=ON \
 | 
				
			||||||
 | 
						-DDISABLE_TC=ON \
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifeq ($(CONFIG_PCAP_HAS_NETFILTER),)
 | 
					# Debugging options
 | 
				
			||||||
CONFIGURE_VARS += \
 | 
					CMAKE_OPTIONS += \
 | 
				
			||||||
	ac_cv_netfilter_can_compile=no
 | 
						-DBDEBUG=OFF \
 | 
				
			||||||
endif
 | 
						-DYYDEBUG=OFF \
 | 
				
			||||||
 | 
					
 | 
				
			||||||
CONFIGURE_ARGS += \
 | 
					CMAKE_OPTIONS += $(if $(CONFIG_PCAP_HAS_USB)       ,,-DDISABLE_USB=ON)
 | 
				
			||||||
	--enable-shared \
 | 
					CMAKE_OPTIONS += $(if $(CONFIG_PCAP_HAS_BT)        ,,-DDISABLE_BLUETOOTH=ON)
 | 
				
			||||||
	--disable-yydebug \
 | 
					CMAKE_OPTIONS += $(if $(CONFIG_PCAP_HAS_NETFILTER) ,,-DPCAP_SUPPORT_NETFILTER=OFF)
 | 
				
			||||||
	--with-pcap=linux \
 | 
					 | 
				
			||||||
	--without-septel \
 | 
					 | 
				
			||||||
	--without-dag \
 | 
					 | 
				
			||||||
	--without-libnl \
 | 
					 | 
				
			||||||
	--without-snf \
 | 
					 | 
				
			||||||
	--disable-can \
 | 
					 | 
				
			||||||
	--disable-canusb \
 | 
					 | 
				
			||||||
	--disable-dbus \
 | 
					 | 
				
			||||||
	--disable-bluetooth
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifeq ($(CONFIG_IPV6),y)
 | 
					CMAKE_OPTIONS += $(if $(CONFIG_IPV6),-DINET6=ON,-DINET6=OFF)
 | 
				
			||||||
CONFIGURE_ARGS += \
 | 
					 | 
				
			||||||
	--enable-ipv6
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
MAKE_FLAGS += \
 | 
					 | 
				
			||||||
	CCOPT="$(TARGET_CFLAGS) -I$(BUILD_DIR)/linux/include"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
define Build/Configure
 | 
					 | 
				
			||||||
	$(call Build/Configure/Default)
 | 
					 | 
				
			||||||
	$(if $(CONFIG_PCAP_HAS_USB),,$(SED) '/^#define PCAP_SUPPORT_USB/D' $(PKG_BUILD_DIR)/config.h)
 | 
					 | 
				
			||||||
	$(if $(CONFIG_PCAP_HAS_USB),,$(SED) 's/pcap-usb-linux.c *//' $(PKG_BUILD_DIR)/Makefile)
 | 
					 | 
				
			||||||
	$(if $(CONFIG_PCAP_HAS_BT),,$(SED) '/^#define PCAP_SUPPORT_BT/D' $(PKG_BUILD_DIR)/config.h)
 | 
					 | 
				
			||||||
	$(if $(CONFIG_PCAP_HAS_BT),,$(SED) 's/pcap-bt-linux.c *//' $(PKG_BUILD_DIR)/Makefile)
 | 
					 | 
				
			||||||
endef
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
define Build/InstallDev
 | 
					 | 
				
			||||||
	$(INSTALL_DIR) $(1)/usr/include
 | 
					 | 
				
			||||||
	$(CP) $(PKG_INSTALL_DIR)/usr/include/pcap* $(1)/usr/include/
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	$(INSTALL_DIR) $(1)/usr/lib
 | 
					 | 
				
			||||||
	$(CP) $(PKG_INSTALL_DIR)/usr/lib/libpcap.{a,so*} $(1)/usr/lib/
 | 
					 | 
				
			||||||
endef
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
define Package/libpcap/install
 | 
					define Package/libpcap/install
 | 
				
			||||||
	$(INSTALL_DIR) $(1)/usr/lib
 | 
						$(INSTALL_DIR) $(1)/usr/lib
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,168 +0,0 @@
 | 
				
			|||||||
Debian-specific modifications to the upstream Makefile.in to
 | 
					 | 
				
			||||||
build a shared library.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
--- a/Makefile.in
 | 
					 | 
				
			||||||
+++ b/Makefile.in
 | 
					 | 
				
			||||||
@@ -40,6 +40,13 @@ mandir = @mandir@
 | 
					 | 
				
			||||||
 srcdir = @srcdir@
 | 
					 | 
				
			||||||
 VPATH = @srcdir@
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
+# some defines for shared library compilation
 | 
					 | 
				
			||||||
+LIBVERSION=1
 | 
					 | 
				
			||||||
+LIBNAME=pcap
 | 
					 | 
				
			||||||
+LIBRARY=lib$(LIBNAME).a
 | 
					 | 
				
			||||||
+SOLIBRARY=lib$(LIBNAME).so
 | 
					 | 
				
			||||||
+SHAREDLIB=$(SOLIBRARY).$(LIBVERSION)
 | 
					 | 
				
			||||||
+
 | 
					 | 
				
			||||||
 #
 | 
					 | 
				
			||||||
 # You shouldn't need to edit anything below.
 | 
					 | 
				
			||||||
 #
 | 
					 | 
				
			||||||
@@ -69,7 +76,8 @@ INSTALL_RPCAPD=@INSTALL_RPCAPD@
 | 
					 | 
				
			||||||
 EXTRA_NETWORK_LIBS=@EXTRA_NETWORK_LIBS@
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
 # Standard CFLAGS for building members of a shared library
 | 
					 | 
				
			||||||
-FULL_CFLAGS = $(CCOPT) @V_LIB_CCOPT_FAT@ $(SHLIB_CCOPT) $(INCLS) $(DEFS) $(CFLAGS)
 | 
					 | 
				
			||||||
+FULL_CFLAGS = $(CCOPT) @V_LIB_CCOPT_FAT@ $(SHLIB_CCOPT) $(INCLS) $(DEFS) $(CFLAGS) $(CPPFLAGS)
 | 
					 | 
				
			||||||
+CFLAGS_SHARED = -shared -Wl,-soname,$(SHAREDLIB)
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
 INSTALL = @INSTALL@
 | 
					 | 
				
			||||||
 INSTALL_PROGRAM = @INSTALL_PROGRAM@
 | 
					 | 
				
			||||||
@@ -84,7 +92,11 @@ YACC = @YACC@
 | 
					 | 
				
			||||||
 # problem if you don't own the file but can write to the directory.
 | 
					 | 
				
			||||||
 .c.o:
 | 
					 | 
				
			||||||
 	@rm -f $@
 | 
					 | 
				
			||||||
-	$(CC) $(FULL_CFLAGS) -c $(srcdir)/$*.c
 | 
					 | 
				
			||||||
+	$(CC) $(FULL_CFLAGS) -c -o $@ $(srcdir)/$*.c
 | 
					 | 
				
			||||||
+
 | 
					 | 
				
			||||||
+%_pic.o: %.c %.o
 | 
					 | 
				
			||||||
+	@rm -f $@
 | 
					 | 
				
			||||||
+	$(CC) -fPIC $(FULL_CFLAGS) -c -o $@ $(srcdir)/$*.c
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
 PSRC =	pcap-@V_PCAP@.c @USB_SRC@ @BT_SRC@ @BT_MONITOR_SRC@ @NETFILTER_SRC@ @DBUS_SRC@ @NETMAP_SRC@ @RDMA_SRC@
 | 
					 | 
				
			||||||
 FSRC =  @V_FINDALLDEVS@
 | 
					 | 
				
			||||||
@@ -101,6 +113,7 @@ SRC =	$(PSRC) $(FSRC) $(CSRC) $(SSRC) $(
 | 
					 | 
				
			||||||
 # We would like to say "OBJ = $(SRC:.c=.o)" but Ultrix's make cannot
 | 
					 | 
				
			||||||
 # hack the extra indirection
 | 
					 | 
				
			||||||
 OBJ =	$(PSRC:.c=.o) $(FSRC:.c=.o) $(CSRC:.c=.o) $(SSRC:.c=.o) $(GENSRC:.c=.o) $(LIBOBJS)
 | 
					 | 
				
			||||||
+OBJ_PIC = $(PSRC:.c=_pic.o) $(FSRC:.c=_pic.o) $(CSRC:.c=_pic.o) $(SSRC:.c=_pic.o) $(GENSRC:.c=_pic.o)
 | 
					 | 
				
			||||||
 PUBHDR = \
 | 
					 | 
				
			||||||
 	pcap.h \
 | 
					 | 
				
			||||||
 	pcap-bpf.h \
 | 
					 | 
				
			||||||
@@ -155,7 +168,7 @@ TAGFILES = \
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
 CLEANFILES = $(OBJ) libpcap.a libpcap.so.`cat $(srcdir)/VERSION` \
 | 
					 | 
				
			||||||
 	$(PROG)-`cat $(srcdir)/VERSION`.tar.gz $(GENSRC) $(GENHDR) \
 | 
					 | 
				
			||||||
-	lex.yy.c pcap-config libpcap.pc
 | 
					 | 
				
			||||||
+	lex.yy.c pcap-config libpcap.pc $(OBJ_PIC)
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
 MAN1 = pcap-config.1
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
@@ -392,7 +405,7 @@ libpcap.a: $(OBJ)
 | 
					 | 
				
			||||||
 	$(AR) rc $@ $(OBJ) $(ADDLARCHIVEOBJS)
 | 
					 | 
				
			||||||
 	$(RANLIB) $@
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
-shared: libpcap.$(DYEXT)
 | 
					 | 
				
			||||||
+shared: $(SHAREDLIB)
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
 libpcap.so: $(OBJ)
 | 
					 | 
				
			||||||
 	@rm -f $@
 | 
					 | 
				
			||||||
@@ -468,6 +481,12 @@ libpcap.shareda: $(OBJ)
 | 
					 | 
				
			||||||
 #
 | 
					 | 
				
			||||||
 libpcap.none:
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
+$(SHAREDLIB): $(OBJ_PIC)
 | 
					 | 
				
			||||||
+	-@rm -f $@
 | 
					 | 
				
			||||||
+	-@rm -f $(SOLIBRARY)
 | 
					 | 
				
			||||||
+	$(CC) $(CFLAGS_SHARED) $(LDFLAGS) -o $(SHAREDLIB) $(OBJ_PIC) -lc $(LIBS)
 | 
					 | 
				
			||||||
+	ln -s $(SHAREDLIB) $(SOLIBRARY)
 | 
					 | 
				
			||||||
+
 | 
					 | 
				
			||||||
 scanner.c: $(srcdir)/scanner.l
 | 
					 | 
				
			||||||
 	$(LEX) -P pcap_ --header-file=scanner.h --nounput -o scanner.c $<
 | 
					 | 
				
			||||||
 scanner.h: scanner.c
 | 
					 | 
				
			||||||
@@ -480,6 +499,9 @@ scanner.h: scanner.c
 | 
					 | 
				
			||||||
 scanner.o: scanner.c grammar.h
 | 
					 | 
				
			||||||
 	$(CC) $(FULL_CFLAGS) -c scanner.c
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
+scanner_pic.o: scanner.c grammar.h
 | 
					 | 
				
			||||||
+	$(CC) -fPIC $(FULL_CFLAGS) -o $@ -c scanner.c
 | 
					 | 
				
			||||||
+
 | 
					 | 
				
			||||||
 grammar.c: $(srcdir)/grammar.y
 | 
					 | 
				
			||||||
 	$(YACC) -p pcap_ -o grammar.c -d $<
 | 
					 | 
				
			||||||
 grammar.h: grammar.c
 | 
					 | 
				
			||||||
@@ -492,6 +514,9 @@ grammar.h: grammar.c
 | 
					 | 
				
			||||||
 grammar.o: grammar.c scanner.h
 | 
					 | 
				
			||||||
 	$(CC) $(FULL_CFLAGS) -c grammar.c
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
+grammar_pic.o: grammar.c scanner.h
 | 
					 | 
				
			||||||
+	$(CC) -fPIC $(FULL_CFLAGS) -o $@ -c grammar.c
 | 
					 | 
				
			||||||
+
 | 
					 | 
				
			||||||
 gencode.o: $(srcdir)/gencode.c grammar.h scanner.h
 | 
					 | 
				
			||||||
 	$(CC) $(FULL_CFLAGS) -c $(srcdir)/gencode.c
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
@@ -539,6 +564,9 @@ pcap-config: $(srcdir)/pcap-config.in ./
 | 
					 | 
				
			||||||
 	mv $@.tmp $@
 | 
					 | 
				
			||||||
 	chmod a+x $@
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
+bpf_filter_pic.o: bpf_filter.c
 | 
					 | 
				
			||||||
+	$(CC) -fPIC $(FULL_CFLAGS) -c bpf_filter.c -o $@
 | 
					 | 
				
			||||||
+
 | 
					 | 
				
			||||||
 #
 | 
					 | 
				
			||||||
 # Remote pcap daemon.
 | 
					 | 
				
			||||||
 #
 | 
					 | 
				
			||||||
@@ -632,14 +660,11 @@ install: install-shared install-archive
 | 
					 | 
				
			||||||
 		    $(DESTDIR)$(mandir)/man@MAN_MISC_INFO@/`echo $$i | sed 's/.manmisc.in/.@MAN_MISC_INFO@/'`; done
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
 install-shared: install-shared-$(DYEXT)
 | 
					 | 
				
			||||||
-install-shared-so: libpcap.so
 | 
					 | 
				
			||||||
+install-shared-so: $(SHAREDLIB)
 | 
					 | 
				
			||||||
 	[ -d $(DESTDIR)$(libdir) ] || \
 | 
					 | 
				
			||||||
 	    (mkdir -p $(DESTDIR)$(libdir); chmod 755 $(DESTDIR)$(libdir))
 | 
					 | 
				
			||||||
-	VER=`cat $(srcdir)/VERSION`; \
 | 
					 | 
				
			||||||
-	MAJOR_VER=`sed 's/\([0-9][0-9]*\)\..*/\1/' $(srcdir)/VERSION`; \
 | 
					 | 
				
			||||||
-	$(INSTALL_PROGRAM) libpcap.so.$$VER $(DESTDIR)$(libdir)/libpcap.so.$$VER; \
 | 
					 | 
				
			||||||
-	ln -sf libpcap.so.$$VER $(DESTDIR)$(libdir)/libpcap.so.$$MAJOR_VER; \
 | 
					 | 
				
			||||||
-	ln -sf libpcap.so.$$MAJOR_VER $(DESTDIR)$(libdir)/libpcap.so
 | 
					 | 
				
			||||||
+	$(INSTALL_DATA) $(SHAREDLIB) $(DESTDIR)$(libdir)/
 | 
					 | 
				
			||||||
+	ln -sf $(SHAREDLIB) $(DESTDIR)$(libdir)/$(SOLIBRARY)
 | 
					 | 
				
			||||||
 install-shared-dylib: libpcap.dylib
 | 
					 | 
				
			||||||
 	[ -d $(DESTDIR)$(libdir) ] || \
 | 
					 | 
				
			||||||
 	    (mkdir -p $(DESTDIR)$(libdir); chmod 755 $(DESTDIR)$(libdir))
 | 
					 | 
				
			||||||
--- a/aclocal.m4
 | 
					 | 
				
			||||||
+++ b/aclocal.m4
 | 
					 | 
				
			||||||
@@ -507,7 +507,7 @@ AC_DEFUN(AC_LBL_SHLIBS_INIT,
 | 
					 | 
				
			||||||
 			esac
 | 
					 | 
				
			||||||
 			;;
 | 
					 | 
				
			||||||
 		    esac
 | 
					 | 
				
			||||||
-		    V_SHLIB_CCOPT="$V_SHLIB_CCOPT $PIC_OPT"
 | 
					 | 
				
			||||||
+		    V_SHLIB_CCOPT="$V_SHLIB_CCOPT"
 | 
					 | 
				
			||||||
 		    V_SONAME_OPT="-Wl,-soname,"
 | 
					 | 
				
			||||||
 		    V_RPATH_OPT="-Wl,-rpath,"
 | 
					 | 
				
			||||||
 		    ;;
 | 
					 | 
				
			||||||
@@ -570,7 +570,7 @@ AC_DEFUN(AC_LBL_SHLIBS_INIT,
 | 
					 | 
				
			||||||
 		    #
 | 
					 | 
				
			||||||
 		    # "cc" is GCC.
 | 
					 | 
				
			||||||
 		    #
 | 
					 | 
				
			||||||
-		    V_SHLIB_CCOPT="$V_SHLIB_CCOPT -fpic"
 | 
					 | 
				
			||||||
+		    V_SHLIB_CCOPT="$V_SHLIB_CCOPT"
 | 
					 | 
				
			||||||
 		    V_SHLIB_CMD="\$(CC)"
 | 
					 | 
				
			||||||
 		    V_SHLIB_OPT="-shared"
 | 
					 | 
				
			||||||
 		    V_SONAME_OPT="-Wl,-soname,"
 | 
					 | 
				
			||||||
--- a/pcap-config.in
 | 
					 | 
				
			||||||
+++ b/pcap-config.in
 | 
					 | 
				
			||||||
@@ -41,16 +41,6 @@ do
 | 
					 | 
				
			||||||
 	esac
 | 
					 | 
				
			||||||
 	shift
 | 
					 | 
				
			||||||
 done
 | 
					 | 
				
			||||||
-if [ "$V_RPATH_OPT" != "" ]
 | 
					 | 
				
			||||||
-then
 | 
					 | 
				
			||||||
-	#
 | 
					 | 
				
			||||||
-	# If libdir isn't /usr/lib, add it to the run-time linker path.
 | 
					 | 
				
			||||||
-	#
 | 
					 | 
				
			||||||
-	if [ "$libdir" != "/usr/lib" ]
 | 
					 | 
				
			||||||
-	then
 | 
					 | 
				
			||||||
-		RPATH=$V_RPATH_OPT$libdir
 | 
					 | 
				
			||||||
-	fi
 | 
					 | 
				
			||||||
-fi
 | 
					 | 
				
			||||||
 if [ "$static" = 1 ]
 | 
					 | 
				
			||||||
 then
 | 
					 | 
				
			||||||
 	#
 | 
					 | 
				
			||||||
@@ -1,77 +0,0 @@
 | 
				
			|||||||
--- a/Makefile.in
 | 
					 | 
				
			||||||
+++ b/Makefile.in
 | 
					 | 
				
			||||||
@@ -588,14 +588,6 @@ install: install-shared install-archive
 | 
					 | 
				
			||||||
 	    (mkdir -p $(DESTDIR)$(includedir); chmod 755 $(DESTDIR)$(includedir))
 | 
					 | 
				
			||||||
 	[ -d $(DESTDIR)$(includedir)/pcap ] || \
 | 
					 | 
				
			||||||
 	    (mkdir -p $(DESTDIR)$(includedir)/pcap; chmod 755 $(DESTDIR)$(includedir)/pcap)
 | 
					 | 
				
			||||||
-	[ -d $(DESTDIR)$(mandir)/man1 ] || \
 | 
					 | 
				
			||||||
-	    (mkdir -p $(DESTDIR)$(mandir)/man1; chmod 755 $(DESTDIR)$(mandir)/man1)
 | 
					 | 
				
			||||||
-	[ -d $(DESTDIR)$(mandir)/man3 ] || \
 | 
					 | 
				
			||||||
-	    (mkdir -p $(DESTDIR)$(mandir)/man3; chmod 755 $(DESTDIR)$(mandir)/man3)
 | 
					 | 
				
			||||||
-	[ -d $(DESTDIR)$(mandir)/man@MAN_FILE_FORMATS@ ] || \
 | 
					 | 
				
			||||||
-	    (mkdir -p $(DESTDIR)$(mandir)/man@MAN_FILE_FORMATS@; chmod 755 $(DESTDIR)$(mandir)/man@MAN_FILE_FORMATS@)
 | 
					 | 
				
			||||||
-	[ -d $(DESTDIR)$(mandir)/man@MAN_MISC_INFO@ ] || \
 | 
					 | 
				
			||||||
-	    (mkdir -p $(DESTDIR)$(mandir)/man@MAN_MISC_INFO@; chmod 755 $(DESTDIR)$(mandir)/man@MAN_MISC_INFO@)
 | 
					 | 
				
			||||||
 	for i in $(PUBHDR); do \
 | 
					 | 
				
			||||||
 		$(INSTALL_DATA) $(srcdir)/$$i \
 | 
					 | 
				
			||||||
 		    $(DESTDIR)$(includedir)/$$i; done
 | 
					 | 
				
			||||||
@@ -605,59 +597,6 @@ install: install-shared install-archive
 | 
					 | 
				
			||||||
 	[ -d $(DESTDIR)$(libdir)/pkgconfig ] || \
 | 
					 | 
				
			||||||
 	    (mkdir -p $(DESTDIR)$(libdir)/pkgconfig; chmod 755 $(DESTDIR)$(libdir)/pkgconfig)
 | 
					 | 
				
			||||||
 	$(INSTALL_DATA) libpcap.pc $(DESTDIR)$(libdir)/pkgconfig/libpcap.pc
 | 
					 | 
				
			||||||
-	for i in $(MAN1); do \
 | 
					 | 
				
			||||||
-		$(INSTALL_DATA) $(srcdir)/$$i \
 | 
					 | 
				
			||||||
-		    $(DESTDIR)$(mandir)/man1/$$i; done
 | 
					 | 
				
			||||||
-	for i in $(MAN3PCAP_NOEXPAND); do \
 | 
					 | 
				
			||||||
-		$(INSTALL_DATA) $(srcdir)/$$i \
 | 
					 | 
				
			||||||
-		    $(DESTDIR)$(mandir)/man3/$$i; done
 | 
					 | 
				
			||||||
-	for i in $(MAN3PCAP_EXPAND:.in=); do \
 | 
					 | 
				
			||||||
-		$(INSTALL_DATA) $$i \
 | 
					 | 
				
			||||||
-		    $(DESTDIR)$(mandir)/man3/$$i; done
 | 
					 | 
				
			||||||
-	(cd $(DESTDIR)$(mandir)/man3 && \
 | 
					 | 
				
			||||||
-	rm -f pcap_datalink_val_to_description.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_datalink_val_to_name.3pcap \
 | 
					 | 
				
			||||||
-		 pcap_datalink_val_to_description.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_datalink_val_to_description_or_dlt.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_datalink_val_to_name.3pcap \
 | 
					 | 
				
			||||||
-		 pcap_datalink_val_to_description_or_dlt.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_dump_fopen.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_dump_open.3pcap pcap_dump_fopen.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_freealldevs.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_findalldevs.3pcap pcap_freealldevs.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_perror.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_geterr.3pcap pcap_perror.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_sendpacket.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_inject.3pcap pcap_sendpacket.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_free_datalinks.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_list_datalinks.3pcap pcap_free_datalinks.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_free_tstamp_types.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_list_tstamp_types.3pcap pcap_free_tstamp_types.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_dispatch.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_loop.3pcap pcap_dispatch.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_minor_version.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_major_version.3pcap pcap_minor_version.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_next.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_next_ex.3pcap pcap_next.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_open_dead_with_tstamp_precision.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_open_dead.3pcap \
 | 
					 | 
				
			||||||
-		 pcap_open_dead_with_tstamp_precision.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_open_offline_with_tstamp_precision.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_open_offline.3pcap pcap_open_offline_with_tstamp_precision.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_fopen_offline.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_open_offline.3pcap pcap_fopen_offline.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_fopen_offline_with_tstamp_precision.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_open_offline.3pcap pcap_fopen_offline_with_tstamp_precision.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_tstamp_type_val_to_description.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_tstamp_type_val_to_name.3pcap pcap_tstamp_type_val_to_description.3pcap && \
 | 
					 | 
				
			||||||
-	rm -f pcap_getnonblock.3pcap && \
 | 
					 | 
				
			||||||
-	$(LN_S) pcap_setnonblock.3pcap pcap_getnonblock.3pcap)
 | 
					 | 
				
			||||||
-	for i in $(MANFILE); do \
 | 
					 | 
				
			||||||
-		$(INSTALL_DATA) `echo $$i | sed 's/.manfile.in/.manfile/'` \
 | 
					 | 
				
			||||||
-		    $(DESTDIR)$(mandir)/man@MAN_FILE_FORMATS@/`echo $$i | sed 's/.manfile.in/.@MAN_FILE_FORMATS@/'`; done
 | 
					 | 
				
			||||||
-	for i in $(MANMISC); do \
 | 
					 | 
				
			||||||
-		$(INSTALL_DATA) `echo $$i | sed 's/.manmisc.in/.manmisc/'` \
 | 
					 | 
				
			||||||
-		    $(DESTDIR)$(mandir)/man@MAN_MISC_INFO@/`echo $$i | sed 's/.manmisc.in/.@MAN_MISC_INFO@/'`; done
 | 
					 | 
				
			||||||
 
 | 
					 | 
				
			||||||
 install-shared: install-shared-$(DYEXT)
 | 
					 | 
				
			||||||
 install-shared-so: $(SHAREDLIB)
 | 
					 | 
				
			||||||
							
								
								
									
										75
									
								
								package/libs/libpcap/patches/102-skip-manpages.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								package/libs/libpcap/patches/102-skip-manpages.patch
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,75 @@
 | 
				
			|||||||
 | 
					From f172e36e436d714f4def1439b13efd147a6a8411 Mon Sep 17 00:00:00 2001
 | 
				
			||||||
 | 
					From: Yousong Zhou <yszhou4tech@gmail.com>
 | 
				
			||||||
 | 
					Date: Fri, 18 Oct 2019 12:43:22 +0000
 | 
				
			||||||
 | 
					Subject: [PATCH] skip manpages
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					---
 | 
				
			||||||
 | 
					 CMakeLists.txt | 55 --------------------------------------------------
 | 
				
			||||||
 | 
					 1 file changed, 55 deletions(-)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					diff --git a/CMakeLists.txt b/CMakeLists.txt
 | 
				
			||||||
 | 
					index 55b93f14..acf1a904 100644
 | 
				
			||||||
 | 
					--- a/CMakeLists.txt
 | 
				
			||||||
 | 
					+++ b/CMakeLists.txt
 | 
				
			||||||
 | 
					@@ -2397,61 +2397,6 @@ if(NOT MSVC)
 | 
				
			||||||
 | 
					     configure_file(${CMAKE_CURRENT_SOURCE_DIR}/libpcap.pc.in ${CMAKE_CURRENT_BINARY_DIR}/libpcap.pc @ONLY)
 | 
				
			||||||
 | 
					     install(PROGRAMS ${CMAKE_CURRENT_BINARY_DIR}/pcap-config DESTINATION bin)
 | 
				
			||||||
 | 
					     install(FILES ${CMAKE_CURRENT_BINARY_DIR}/libpcap.pc DESTINATION lib/pkgconfig)
 | 
				
			||||||
 | 
					-
 | 
				
			||||||
 | 
					-    #
 | 
				
			||||||
 | 
					-    # Man pages.
 | 
				
			||||||
 | 
					-    #
 | 
				
			||||||
 | 
					-    # For each section of the manual for which we have man pages
 | 
				
			||||||
 | 
					-    # that require macro expansion, do the expansion.
 | 
				
			||||||
 | 
					-    #
 | 
				
			||||||
 | 
					-    set(MAN1 "")
 | 
				
			||||||
 | 
					-    foreach(MANPAGE ${MAN1_NOEXPAND})
 | 
				
			||||||
 | 
					-        set(MAN1 ${MAN1} ${CMAKE_CURRENT_SOURCE_DIR}/${MANPAGE})
 | 
				
			||||||
 | 
					-    endforeach(MANPAGE)
 | 
				
			||||||
 | 
					-    install(FILES ${MAN1} DESTINATION ${CMAKE_INSTALL_MANDIR}/man1)
 | 
				
			||||||
 | 
					-
 | 
				
			||||||
 | 
					-    set(MAN3PCAP "")
 | 
				
			||||||
 | 
					-    foreach(MANPAGE ${MAN3PCAP_NOEXPAND})
 | 
				
			||||||
 | 
					-        set(MAN3PCAP ${MAN3PCAP} ${CMAKE_CURRENT_SOURCE_DIR}/${MANPAGE})
 | 
				
			||||||
 | 
					-    endforeach(MANPAGE)
 | 
				
			||||||
 | 
					-    foreach(TEMPLATE_MANPAGE ${MAN3PCAP_EXPAND})
 | 
				
			||||||
 | 
					-        string(REPLACE ".in" "" MANPAGE ${TEMPLATE_MANPAGE})
 | 
				
			||||||
 | 
					-        configure_file(${CMAKE_CURRENT_SOURCE_DIR}/${TEMPLATE_MANPAGE} ${CMAKE_CURRENT_BINARY_DIR}/${MANPAGE} @ONLY)
 | 
				
			||||||
 | 
					-        set(MAN3PCAP ${MAN3PCAP} ${CMAKE_CURRENT_BINARY_DIR}/${MANPAGE})
 | 
				
			||||||
 | 
					-    endforeach(TEMPLATE_MANPAGE)
 | 
				
			||||||
 | 
					-    install(FILES ${MAN3PCAP} DESTINATION ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_datalink_val_to_name.3pcap pcap_datalink_val_to_description.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_dump_open.3pcap pcap_dump_fopen.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_findalldevs.3pcap pcap_freealldevs.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_geterr.3pcap pcap_perror.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_inject.3pcap pcap_sendpacket.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_list_datalinks.3pcap pcap_free_datalinks.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_list_tstamp_types.3pcap pcap_free_tstamp_types.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_loop.3pcap pcap_dispatch.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_major_version.3pcap pcap_minor_version.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_next_ex.3pcap pcap_next.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_open_dead.3pcap pcap_open_dead_with_tstamp_precision.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_open_offline.3pcap pcap_open_offline_with_tstamp_precision.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_open_offline.3pcap pcap_fopen_offline.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_open_offline.3pcap pcap_fopen_offline_with_tstamp_precision.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_tstamp_type_val_to_name.3pcap pcap_tstamp_type_val_to_description.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-    install_manpage_symlink(pcap_setnonblock.3pcap pcap_getnonblock.3pcap ${CMAKE_INSTALL_MANDIR}/man3)
 | 
				
			||||||
 | 
					-
 | 
				
			||||||
 | 
					-    set(MANFILE "")
 | 
				
			||||||
 | 
					-    foreach(TEMPLATE_MANPAGE ${MANFILE_EXPAND})
 | 
				
			||||||
 | 
					-        string(REPLACE ".manfile.in" ".${MAN_FILE_FORMATS}" MANPAGE ${TEMPLATE_MANPAGE})
 | 
				
			||||||
 | 
					-        configure_file(${CMAKE_CURRENT_SOURCE_DIR}/${TEMPLATE_MANPAGE} ${CMAKE_CURRENT_BINARY_DIR}/${MANPAGE} @ONLY)
 | 
				
			||||||
 | 
					-        set(MANFILE ${MANFILE} ${CMAKE_CURRENT_BINARY_DIR}/${MANPAGE})
 | 
				
			||||||
 | 
					-    endforeach(TEMPLATE_MANPAGE)
 | 
				
			||||||
 | 
					-    install(FILES ${MANFILE} DESTINATION ${CMAKE_INSTALL_MANDIR}/man${MAN_FILE_FORMATS})
 | 
				
			||||||
 | 
					-
 | 
				
			||||||
 | 
					-    set(MANMISC "")
 | 
				
			||||||
 | 
					-    foreach(TEMPLATE_MANPAGE ${MANMISC_EXPAND})
 | 
				
			||||||
 | 
					-        string(REPLACE ".manmisc.in" ".${MAN_MISC_INFO}" MANPAGE ${TEMPLATE_MANPAGE})
 | 
				
			||||||
 | 
					-        configure_file(${CMAKE_CURRENT_SOURCE_DIR}/${TEMPLATE_MANPAGE} ${CMAKE_CURRENT_BINARY_DIR}/${MANPAGE} @ONLY)
 | 
				
			||||||
 | 
					-        set(MANMISC ${MANMISC} ${CMAKE_CURRENT_BINARY_DIR}/${MANPAGE})
 | 
				
			||||||
 | 
					-    endforeach(TEMPLATE_MANPAGE)
 | 
				
			||||||
 | 
					-    install(FILES ${MANMISC} DESTINATION ${CMAKE_INSTALL_MANDIR}/man${MAN_MISC_INFO})
 | 
				
			||||||
 | 
					 endif(NOT MSVC)
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 # uninstall target
 | 
				
			||||||
		Reference in New Issue
	
	Block a user