aboutsummaryrefslogtreecommitdiffstats
path: root/comms/hidapi
diff options
context:
space:
mode:
authortijl <tijl@FreeBSD.org>2014-01-04 04:42:35 +0800
committertijl <tijl@FreeBSD.org>2014-01-04 04:42:35 +0800
commit78ebf8bcbd86984978d8b0e8db63c70ce3184287 (patch)
tree4099a3dcda435a57d07e8bd3b7b787d16e921af2 /comms/hidapi
parent416ae895c880565c0a8434bca9c5873217350316 (diff)
downloadfreebsd-ports-gnome-78ebf8bcbd86984978d8b0e8db63c70ce3184287.tar.gz
freebsd-ports-gnome-78ebf8bcbd86984978d8b0e8db63c70ce3184287.tar.zst
freebsd-ports-gnome-78ebf8bcbd86984978d8b0e8db63c70ce3184287.zip
New port comms/hidapi.
HIDAPI is a platform independent library that allows applications to work with USB HID-Class devices. While it can be used to communicate with standard HID devices like keyboards, mice, and joysticks, it is most useful when used with custom (Vendor-Defined) HID devices.
Diffstat (limited to 'comms/hidapi')
-rw-r--r--comms/hidapi/Makefile24
-rw-r--r--comms/hidapi/distinfo2
-rw-r--r--comms/hidapi/files/patch-configure.ac12
-rw-r--r--comms/hidapi/files/patch-libusb-hid.c72
-rw-r--r--comms/hidapi/pkg-descr6
-rw-r--r--comms/hidapi/pkg-plist7
6 files changed, 123 insertions, 0 deletions
diff --git a/comms/hidapi/Makefile b/comms/hidapi/Makefile
new file mode 100644
index 000000000000..ef644514e36f
--- /dev/null
+++ b/comms/hidapi/Makefile
@@ -0,0 +1,24 @@
+# $FreeBSD$
+
+PORTNAME= hidapi
+DISTVERSION= 0.8.0-rc1
+CATEGORIES= comms
+
+MAINTAINER= tijl@FreeBSD.org
+COMMENT= Library to access USB HID-class devices
+
+LICENSE= BSD3CLAUSE GPLv3
+LICENSE_COMB= dual
+
+USE_GITHUB= yes
+GH_ACCOUNT= signal11
+GH_TAGNAME= ${PORTNAME}-${DISTVERSION}
+GH_COMMIT= 40cf516
+
+USE_AUTOTOOLS= aclocal autoconf autoheader automake libtoolize
+AUTOMAKE_ARGS= --add-missing
+
+USES= iconv
+USE_LDCONFIG= yes
+
+.include <bsd.port.mk>
diff --git a/comms/hidapi/distinfo b/comms/hidapi/distinfo
new file mode 100644
index 000000000000..d4478af19049
--- /dev/null
+++ b/comms/hidapi/distinfo
@@ -0,0 +1,2 @@
+SHA256 (hidapi-0.8.0-rc1.tar.gz) = 8cfea344b17d1dbd4d22fab70169307f5f0fbcf5f11f472322685d8d9f38d7ae
+SIZE (hidapi-0.8.0-rc1.tar.gz) = 101821
diff --git a/comms/hidapi/files/patch-configure.ac b/comms/hidapi/files/patch-configure.ac
new file mode 100644
index 000000000000..c443da8ec654
--- /dev/null
+++ b/comms/hidapi/files/patch-configure.ac
@@ -0,0 +1,12 @@
+--- configure.ac.orig
++++ configure.ac
+@@ -93,7 +93,8 @@
+ LDFLAGS="$LDFLAGS -L/usr/local/lib"
+ LIBS="${LIBS}"
+ AC_CHECK_LIB([usb], [libusb_init], [LIBS_LIBUSB_PRIVATE="${LIBS_LIBUSB_PRIVATE} -lusb"], [hidapi_lib_error libusb])
+- AC_CHECK_LIB([iconv], [iconv_open], [LIBS_LIBUSB_PRIVATE="${LIBS_LIBUSB_PRIVATE} -liconv"], [hidapi_lib_error libiconv])
++ AC_CHECK_DECLS([libusb_get_string_descriptor], [], [], [[#include <libusb.h>]])
++ AC_SEARCH_LIBS([iconv_open], [iconv], [], [hidapi_lib_error libiconv])
+ echo libs_priv: $LIBS_LIBUSB_PRIVATE
+ ;;
+ *-mingw*)
diff --git a/comms/hidapi/files/patch-libusb-hid.c b/comms/hidapi/files/patch-libusb-hid.c
new file mode 100644
index 000000000000..5a8968eab24e
--- /dev/null
+++ b/comms/hidapi/files/patch-libusb-hid.c
@@ -0,0 +1,72 @@
+--- libusb/hid.c.orig
++++ libusb/hid.c
+@@ -25,6 +25,8 @@
+
+ #define _GNU_SOURCE /* needed for wcsdup() before glibc 2.10 */
+
++#include <config.h>
++
+ /* C */
+ #include <stdio.h>
+ #include <string.h>
+@@ -250,7 +252,7 @@
+ }
+ #endif /* INVASIVE_GET_USAGE */
+
+-#ifdef __FreeBSD__
++#if ! HAVE_DECL_LIBUSB_GET_STRING_DESCRIPTOR
+ /* The FreeBSD version of libusb doesn't have this funciton. In mainline
+ libusb, it's inlined in libusb.h. This function will bear a striking
+ resemblence to that one, because there's about one way to code it.
+@@ -324,6 +326,7 @@
+ static wchar_t *get_usb_string(libusb_device_handle *dev, uint8_t idx)
+ {
+ char buf[512];
++ char buf2[512];
+ int len;
+ wchar_t *str = NULL;
+ wchar_t wbuf[256];
+@@ -359,7 +362,7 @@
+ it is only passed into iconv() which does not need it. */
+
+ /* Initialize iconv. */
+- ic = iconv_open("WCHAR_T", "UTF-16LE");
++ ic = iconv_open("char", "UTF-16LE");
+ if (ic == (iconv_t)-1) {
+ LOG("iconv_open() failed\n");
+ return NULL;
+@@ -369,18 +372,21 @@
+ Skip the first character (2-bytes). */
+ inptr = buf+2;
+ inbytes = len-2;
+- outptr = (char*) wbuf;
+- outbytes = sizeof(wbuf);
++ outptr = buf2;
++ outbytes = sizeof(buf2);
+ res = iconv(ic, &inptr, &inbytes, &outptr, &outbytes);
+ if (res == (size_t)-1) {
+ LOG("iconv() failed\n");
+ goto err;
+ }
++ res = mbstowcs(wbuf, buf2, sizeof(wbuf)/sizeof(wbuf[0]));
++ if (res == (size_t)-1) {
++ LOG("mbstowcs() failed\n");
++ goto err;
++ }
+
+ /* Write the terminating NULL. */
+ wbuf[sizeof(wbuf)/sizeof(wbuf[0])-1] = 0x00000000;
+- if (outbytes >= sizeof(wbuf[0]))
+- *((wchar_t*)outptr) = 0x00000000;
+
+ /* Allocate and copy the string. */
+ str = wcsdup(wbuf);
+@@ -757,7 +763,7 @@
+ libusb_cancel_transfer(dev->transfer);
+
+ while (!dev->cancelled)
+- libusb_handle_events_completed(usb_context, &dev->cancelled);
++ libusb_handle_events(usb_context);
+
+ /* Now that the read thread is stopping, Wake any threads which are
+ waiting on data (in hid_read_timeout()). Do this under a mutex to
diff --git a/comms/hidapi/pkg-descr b/comms/hidapi/pkg-descr
new file mode 100644
index 000000000000..7b67c9fb323e
--- /dev/null
+++ b/comms/hidapi/pkg-descr
@@ -0,0 +1,6 @@
+HIDAPI is a platform independent library that allows applications to
+work with USB HID-Class devices. While it can be used to communicate
+with standard HID devices like keyboards, mice, and joysticks, it is
+most useful when used with custom (Vendor-Defined) HID devices.
+
+WWW: http://www.signal11.us/oss/hidapi/
diff --git a/comms/hidapi/pkg-plist b/comms/hidapi/pkg-plist
new file mode 100644
index 000000000000..21941c92edc6
--- /dev/null
+++ b/comms/hidapi/pkg-plist
@@ -0,0 +1,7 @@
+include/hidapi/hidapi.h
+lib/libhidapi.a
+lib/libhidapi.la
+lib/libhidapi.so
+lib/libhidapi.so.0
+libdata/pkgconfig/hidapi.pc
+@dirrm include/hidapi