pkgsrc-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[pkgsrc/trunk]: pkgsrc libusb1: Fix PR pkg/54903
details: https://anonhg.NetBSD.org/pkgsrc/rev/ed9050015200
branches: trunk
changeset: 440520:ed9050015200
user: triaxx <triaxx%pkgsrc.org@localhost>
date: Sat Oct 10 14:17:02 2020 +0000
description:
libusb1: Fix PR pkg/54903
pkgsrc changes:
---------------
* Remove the pkgconfig file generation since the version of libusb1 cannot
be obtained by parsing LIBUSB_API_VERSION from libusb.h (e.g. FreeBSD
provides 0x01000102 for 1.0.13 and Arch provides 0x01000107 for 1.0.23).
* At least FreeBSD, Debian and Arch provides a libusb-1.0.pc file for
their native implementation. Link this file to ${BUILDLINK_DIR}.
* Add logic in mk/buildlink3 to find pkgconfig files in common pkgconfig
directories (for at least FreeBSD, Debian and Arch).
diffstat:
devel/libusb1/builtin.mk | 36 +++++---------
mk/buildlink3/bsd.builtin.mk | 3 +-
mk/buildlink3/find-pkgconfig-files.mk | 83 +++++++++++++++++++++++++++++++++++
3 files changed, 98 insertions(+), 24 deletions(-)
diffs (163 lines):
diff -r 0512f14a8cca -r ed9050015200 devel/libusb1/builtin.mk
--- a/devel/libusb1/builtin.mk Sat Oct 10 14:02:37 2020 +0000
+++ b/devel/libusb1/builtin.mk Sat Oct 10 14:17:02 2020 +0000
@@ -1,15 +1,15 @@
-# $NetBSD: builtin.mk,v 1.4 2020/05/25 06:47:40 plunky Exp $
+# $NetBSD: builtin.mk,v 1.5 2020/10/10 14:17:02 triaxx Exp $
BUILTIN_PKG:= libusb1
-BUILTIN_FIND_HEADERS_VAR:= H_LIBUSB
-BUILTIN_FIND_HEADERS.H_LIBUSB= libusb.h
+BUILTIN_FIND_PKGCONFIG_FILES_VAR:= PC_LIBUSB1
+BUILTIN_FIND_PKGCONFIG_FILES.PC_LIBUSB1= libusb-1.0.pc
.include "../../mk/buildlink3/bsd.builtin.mk"
.if !defined(IS_BUILTIN.libusb1)
IS_BUILTIN.libusb1= no
-. if empty(H_LIBUSB:M__nonexistent__)
+. if empty(PC_LIBUSB1:M__nonexistent__)
IS_BUILTIN.libusb1= yes
. endif
.endif
@@ -21,29 +21,19 @@
.if !empty(USE_BUILTIN.libusb1:M[yY][eE][sS])
. if !empty(USE_TOOLS:C/:.*//:Mpkg-config)
-do-configure-pre-hook: override-libusb-pkgconfig
+do-configure-pre-hook: link-libusb-pkgconfig
-BLKDIR_PKGCFG= ${BUILDLINK_DIR}/lib/pkgconfig
-LIBUSB_PKGCFGF= libusb-1.0.pc
+BLKDIR_PKGCFG= ${BUILDLINK_DIR}/lib/pkgconfig
+LIBUSB1_PKGCFGF= ${BUILTIN_FIND_PKGCONFIG_FILES.PC_LIBUSB1}
-override-libusb-pkgconfig: override-message-libusb-pkgconfig
-override-message-libusb-pkgconfig:
- @${STEP_MSG} "Generating pkg-config file for builtin libusb1 package."
+.PHONY: link-libusb-pkgconfig link-message-libusb-pkgconfig
+link-libusb-pkgconfig: link-message-libusb-pkgconfig
+link-message-libusb-pkgconfig:
+ @${STEP_MSG} "Linking ${PC_LIBUSB1} file into ${BUILDLINK_DIR}."
-override-libusb-pkgconfig:
+link-libusb-pkgconfig:
${RUN} \
${MKDIR} ${BLKDIR_PKGCFG}; \
- { \
- ${ECHO} "prefix=${LIBUSB_PREFIX}"; \
- ${ECHO} "exec_prefix=\$${prefix}"; \
- ${ECHO} "libdir=\$${exec_prefix}/lib"; \
- ${ECHO} "includedir=\$${prefix}/include"; \
- ${ECHO} ""; \
- ${ECHO} "Name: libusb-1.0"; \
- ${ECHO} "Description: library for USB access"; \
- ${ECHO} "Version: ${BUILTIN_VERSION.libusb1}"; \
- ${ECHO} "Libs: ${COMPILER_RPATH_FLAG}\$${libdir} -L\$${libdir} -lusb"; \
- ${ECHO} "Cflags: -I\$${includedir}"; \
- } >> ${BLKDIR_PKGCFG}/${LIBUSB_PKGCFGF};
+ ${LN} -sf ${PC_LIBUSB1} ${BLKDIR_PKGCFG}/${LIBUSB1_PKGCFGF}
. endif
.endif
diff -r 0512f14a8cca -r ed9050015200 mk/buildlink3/bsd.builtin.mk
--- a/mk/buildlink3/bsd.builtin.mk Sat Oct 10 14:02:37 2020 +0000
+++ b/mk/buildlink3/bsd.builtin.mk Sat Oct 10 14:17:02 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: bsd.builtin.mk,v 1.14 2018/08/22 20:48:36 maya Exp $
+# $NetBSD: bsd.builtin.mk,v 1.15 2020/10/10 14:17:03 triaxx Exp $
#
# Copyright (c) 2004-2005 The NetBSD Foundation, Inc.
# All rights reserved.
@@ -166,3 +166,4 @@
.include "../../mk/buildlink3/find-libs.mk"
.include "../../mk/buildlink3/find-headers.mk"
.include "../../mk/buildlink3/find-files.mk"
+.include "../../mk/buildlink3/find-pkgconfig-files.mk"
diff -r 0512f14a8cca -r ed9050015200 mk/buildlink3/find-pkgconfig-files.mk
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/mk/buildlink3/find-pkgconfig-files.mk Sat Oct 10 14:17:02 2020 +0000
@@ -0,0 +1,83 @@
+# $NetBSD: find-pkgconfig-files.mk,v 1.1 2020/10/10 14:17:03 triaxx Exp $
+#
+# Copyright (c) 2020 The NetBSD Foundation, Inc.
+# All rights reserved.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions
+# are met:
+# 1. Redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+# 2. Redistributions in binary form must reproduce the above copyright
+# notice, this list of conditions and the following disclaimer in the
+# documentation and/or other materials provided with the distribution.
+#
+# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+
+#
+# This is a "subroutine" that can be included to detect the presence of
+# pkg-config files in the base system.
+#
+# The following variables must be defined before including this file:
+#
+# BUILTIN_FIND_PKGCONFIG_VAR is a list of variables to define. These
+# variables take the value of the path to the file that is
+# "found".
+#
+# BUILTIN_FIND_PKGCONFIG.<var> is the list of header files to find, in
+# order, on the ${BUILTIN_PKGCONFIG_DIRS}. The variable <var> is set
+# to the first path "found" on the filesystem.
+#
+# After including this file, the following variables are defined:
+#
+# <var> is the first of the header file listed in
+# ${BUILTIN_FIND_PKGCONFIG.<var>} that is "found" in
+# ${BUILTIN_PKGCONFIG_DIRS}, or else it is "__nonexistent__".
+#
+# An example use is:
+#
+# BUILTIN_FIND_PKGCONFIG_FILES_VAR:= LIB1 LIB2
+#
+# BUILTIN_FIND_PKGCONFIG_FILES.LIB1= lib1.pc lib-1.0.pc
+
+# BUILTIN_FIND_PKGCONFIG_FILES.LIB2= lib2.pc lib-2.0.pc
+# .include "../../mk/buildlink3/find-pkgconfig-files.mk"
+#
+
+BUILTIN_PKGCONFIG_DIRS?= /usr/lib/pkgconfig \
+ /usr/share/pkgconfig \
+ /usr/libdata/pkgconfig \
+ /usr/lib/x86_64-linux-gnu/pkgconfig \
+ /usr/lib/aarch64-linux-gnu/pkgconfig \
+ /usr/lib/arm-linux-gnueabi/pkgconfig \
+ /usr/lib/arm-linux-gnueabihf/pkgconfig \
+ /usr/lib/i386-linux-gnu/pkgconfig \
+ /usr/lib/mips64el-linux-gnuabi64/pkgconfig \
+ /usr/lib/mipsel-linux-gnu/pkgconfig \
+ /usr/lib/powerpc64le-linux-gnu/pkgconfig \
+ /usr/lib/s390x-linux-gnu/pkgconfig
+
+.for _var_ in ${BUILTIN_FIND_PKGCONFIG_FILES_VAR}
+. if !defined(${_var_})
+${_var_}= __nonexistent__
+. for _file_ in ${BUILTIN_FIND_PKGCONFIG_FILES.${_var_}}
+. for _dir_ in ${BUILTIN_PKGCONFIG_DIRS}
+. if !empty(${_var_}:M__nonexistent__) && exists(${_dir_}/${_file_})
+${_var_}= ${_dir_}/${_file_}
+. endif
+. endfor
+. endfor
+. endif
+MAKEVARS+= ${_var_}
+.endfor
Home |
Main Index |
Thread Index |
Old Index