diff options
author | nox <nox@FreeBSD.org> | 2011-03-27 03:21:27 +0800 |
---|---|---|
committer | nox <nox@FreeBSD.org> | 2011-03-27 03:21:27 +0800 |
commit | cedd811d8ec9a374779442bf27998ae7d16a6fd8 (patch) | |
tree | a63625256cbddf53a88af3a653420b790242cdb2 | |
parent | b075cb6abcca849cfbcc5fe50eb0cef1e240488f (diff) | |
download | freebsd-ports-gnome-cedd811d8ec9a374779442bf27998ae7d16a6fd8.tar.gz freebsd-ports-gnome-cedd811d8ec9a374779442bf27998ae7d16a6fd8.tar.zst freebsd-ports-gnome-cedd811d8ec9a374779442bf27998ae7d16a6fd8.zip |
http://www.vdr-wiki.de/wiki/index.php/Vnsi-server-plugin
VDR-Network-Streaming-Interface plugin (untested, currently used by
the XBMC pvr-testing2 branch which hasn't been ported to FreeBSD yet
at the time of writing.)
WWW: http://www.vdr-portal.de/board/thread.php?threadid=95292
-rw-r--r-- | multimedia/Makefile | 1 | ||||
-rw-r--r-- | multimedia/vdr-plugin-vnsiserver/Makefile | 39 | ||||
-rw-r--r-- | multimedia/vdr-plugin-vnsiserver/distinfo | 2 | ||||
-rw-r--r-- | multimedia/vdr-plugin-vnsiserver/files/patch-Makefile | 33 | ||||
-rw-r--r-- | multimedia/vdr-plugin-vnsiserver/files/patch-cxsocket.c | 20 | ||||
-rw-r--r-- | multimedia/vdr-plugin-vnsiserver/files/patch-cxsocket.h | 12 | ||||
-rw-r--r-- | multimedia/vdr-plugin-vnsiserver/files/patch-recplayer.c | 13 | ||||
-rw-r--r-- | multimedia/vdr-plugin-vnsiserver/files/patch-responsepacket.c | 10 | ||||
-rw-r--r-- | multimedia/vdr-plugin-vnsiserver/files/patch-server.c | 18 | ||||
-rw-r--r-- | multimedia/vdr-plugin-vnsiserver/pkg-descr | 7 | ||||
-rw-r--r-- | multimedia/vdr-plugin-vnsiserver/pkg-plist | 5 |
11 files changed, 160 insertions, 0 deletions
diff --git a/multimedia/Makefile b/multimedia/Makefile index 0ea88fa9e8ab..4ef93593a6f8 100644 --- a/multimedia/Makefile +++ b/multimedia/Makefile @@ -347,6 +347,7 @@ SUBDIR += vdr-plugin-softdevice SUBDIR += vdr-plugin-streamdev SUBDIR += vdr-plugin-upnp + SUBDIR += vdr-plugin-vnsiserver SUBDIR += vic SUBDIR += vlc SUBDIR += vodcatcher diff --git a/multimedia/vdr-plugin-vnsiserver/Makefile b/multimedia/vdr-plugin-vnsiserver/Makefile new file mode 100644 index 000000000000..16689f1c6583 --- /dev/null +++ b/multimedia/vdr-plugin-vnsiserver/Makefile @@ -0,0 +1,39 @@ +# New ports collection makefile for: vdr-plugin-vnsiserver +# Date created: Tue Oct 5 21:13:30 CEST 2010 +# Whom: Juergen Lock <nox@freebsd.org> +# +# $FreeBSD$ +# + +PORTNAME= vdr-plugin-vnsiserver +PORTVERSION= 0.0.2s20100808.0952 +PORTREVISION= 6 +CATEGORIES= multimedia +MASTER_SITES= http://ppa.launchpad.net/yavdr/testing-vdr/ubuntu/pool/main/v/vdr-plugin-vnsiserver/ +DISTNAME= ${PORTNAME}_${DISTVERSIONPREFIX}${DISTVERSION:S/s20/+svn20/}${DISTVERSIONSUFFIX}.orig + +MAINTAINER= nox@FreeBSD.org +COMMENT= Video Disk Recorder - VNSI server plugin + +PATCH_STRIP= -p1 +HAVE_CONFIGURE= yes +PORTDOCS= COPYING README +MAKE_JOBS_SAFE= yes +WRKSRC= ${WRKDIR}/${PORTNAME}-${DISTVERSIONPREFIX}${DISTVERSION:S/s20/+svn20/}${DISTVERSIONSUFFIX} + +.include "${.CURDIR}/../vdr/Makefile.plugins" + +post-patch: post-patch-plugin + +post-install: + @${MKDIR} ${PREFIX}/etc/vdr/plugins/${PLUGIN} + @${INSTALL_DATA} ${WRKSRC}/${PLUGIN}/allowed_hosts.conf ${PREFIX}/etc/vdr/plugins/${PLUGIN}/allowed_hosts.conf.sample + @if [ ! -f ${PREFIX}/etc/vdr/plugins/${PLUGIN}/allowed_hosts.conf ]; then \ + ${INSTALL_DATA} -o ${VDR_USER} -g ${VDR_GROUP} ${WRKSRC}/${PLUGIN}/allowed_hosts.conf ${PREFIX}/etc/vdr/plugins/${PLUGIN}; \ + fi +.if !defined(NOPORTDOCS) + ${MKDIR} ${DOCSDIR} + (cd ${WRKSRC} && ${INSTALL_DATA} ${PORTDOCS} ${DOCSDIR}) +.endif + +.include <bsd.port.mk> diff --git a/multimedia/vdr-plugin-vnsiserver/distinfo b/multimedia/vdr-plugin-vnsiserver/distinfo new file mode 100644 index 000000000000..b491bf2a0359 --- /dev/null +++ b/multimedia/vdr-plugin-vnsiserver/distinfo @@ -0,0 +1,2 @@ +SHA256 (vdr/vdr-plugin-vnsiserver_0.0.2+svn20100808.0952.orig.tar.gz) = 3763fe0cc853c7e9e22196f4bab5bbf7ce56efac82c44de1e3ab1c6f40a9e375 +SIZE (vdr/vdr-plugin-vnsiserver_0.0.2+svn20100808.0952.orig.tar.gz) = 110497 diff --git a/multimedia/vdr-plugin-vnsiserver/files/patch-Makefile b/multimedia/vdr-plugin-vnsiserver/files/patch-Makefile new file mode 100644 index 000000000000..1fdc0f623903 --- /dev/null +++ b/multimedia/vdr-plugin-vnsiserver/files/patch-Makefile @@ -0,0 +1,33 @@ +--- a/Makefile ++++ b/Makefile +@@ -45,7 +45,11 @@ PACKAGE = vdr-$(ARCHIVE) + + ### Includes and Defines (add further entries here): + ++ifdef FREEBSD ++INCLUDES += -I$(VDRDIR) ++else + INCLUDES += -I$(VDRDIR)/include ++endif + + DEFINES += -D_GNU_SOURCE -DPLUGIN_NAME_I18N='"$(PLUGIN)"' + +@@ -109,7 +113,11 @@ i18n: $(I18Nmsgs) $(I18Npot) + + libvdr-$(PLUGIN).so: $(OBJS) + $(CXX) $(CXXFLAGS) -shared $(LIBS) $(OBJS) -o $@ ++ifdef FREEBSD ++ @cp -f $@ $(LIBDIR)/$@.$(APIVERSION) ++else + @cp --remove-destination $@ $(LIBDIR)/$@.$(APIVERSION) ++endif + + dist: clean + @-rm -rf $(TMPDIR)/$(ARCHIVE) +@@ -121,3 +129,6 @@ dist: clean + + clean: + @-rm -f $(OBJS) $(DEPFILE) *.so *.tgz core* *~ $(PODIR)/*.mo $(PODIR)/*.pot ++ ++install: ++ ${INSTALL_PROGRAM} $(LIBDIR)/libvdr-$(PLUGIN).so.$(APIVERSION) $(PREFIX)/lib/vdr/libvdr-$(PLUGIN).so.$(APIVERSION) diff --git a/multimedia/vdr-plugin-vnsiserver/files/patch-cxsocket.c b/multimedia/vdr-plugin-vnsiserver/files/patch-cxsocket.c new file mode 100644 index 000000000000..42c1cd5e50f7 --- /dev/null +++ b/multimedia/vdr-plugin-vnsiserver/files/patch-cxsocket.c @@ -0,0 +1,20 @@ +--- a/cxsocket.c ++++ b/cxsocket.c +@@ -35,7 +35,7 @@ + #include <sys/types.h> + #include <sys/socket.h> + #include <sys/ioctl.h> +-#ifndef __APPLE__ ++#if !defined(__APPLE__) && !defined(__FreeBSD__) + # include <sys/sendfile.h> + #endif + #include <netinet/tcp.h> +@@ -191,7 +191,7 @@ bool cxSocket::set_multicast(int ttl) + + bool cxSocket::set_cork(bool state) + { +-#ifdef __APPLE__ ++#if defined(__APPLE__) || defined(__FreeBSD__) + return false; + #else + int iCork = state ? 1 : 0; diff --git a/multimedia/vdr-plugin-vnsiserver/files/patch-cxsocket.h b/multimedia/vdr-plugin-vnsiserver/files/patch-cxsocket.h new file mode 100644 index 000000000000..0f296448ea69 --- /dev/null +++ b/multimedia/vdr-plugin-vnsiserver/files/patch-cxsocket.h @@ -0,0 +1,12 @@ +--- a/cxsocket.h ++++ b/cxsocket.h +@@ -29,6 +29,9 @@ + #ifndef __CXSOCKET_H + #define __CXSOCKET_H + ++#ifdef __FreeBSD__ ++#include <netinet/in.h> ++#endif + #include <inttypes.h> + #include <sys/types.h> + #include <sys/socket.h> diff --git a/multimedia/vdr-plugin-vnsiserver/files/patch-recplayer.c b/multimedia/vdr-plugin-vnsiserver/files/patch-recplayer.c new file mode 100644 index 000000000000..a58fcdd5d785 --- /dev/null +++ b/multimedia/vdr-plugin-vnsiserver/files/patch-recplayer.c @@ -0,0 +1,13 @@ +--- a/recplayer.c ++++ b/recplayer.c +@@ -189,8 +189,10 @@ unsigned long cRecPlayer::getBlock(unsig + fseek(m_file, filePosition, SEEK_SET); + fread(&buffer[got], getFromThisSegment, 1, m_file); + ++#ifndef __FreeBSD__ + // Tell linux not to bother keeping the data in the FS cache + posix_fadvise(m_file->_fileno, filePosition, getFromThisSegment, POSIX_FADV_DONTNEED); ++#endif + + got += getFromThisSegment; + currentPosition += getFromThisSegment; diff --git a/multimedia/vdr-plugin-vnsiserver/files/patch-responsepacket.c b/multimedia/vdr-plugin-vnsiserver/files/patch-responsepacket.c new file mode 100644 index 000000000000..2fce82ada736 --- /dev/null +++ b/multimedia/vdr-plugin-vnsiserver/files/patch-responsepacket.c @@ -0,0 +1,10 @@ +--- a/responsepacket.c ++++ b/responsepacket.c +@@ -27,6 +27,7 @@ + #include <arpa/inet.h> + #include <stdlib.h> + #include <string.h> ++#include <inttypes.h> + + #include "responsepacket.h" + #include "vdrcommand.h" diff --git a/multimedia/vdr-plugin-vnsiserver/files/patch-server.c b/multimedia/vdr-plugin-vnsiserver/files/patch-server.c new file mode 100644 index 000000000000..b07abaf2986d --- /dev/null +++ b/multimedia/vdr-plugin-vnsiserver/files/patch-server.c @@ -0,0 +1,18 @@ +--- a/server.c ++++ b/server.c +@@ -151,6 +151,7 @@ void cServer::NewClientConnected(int fd) + int val = 1; + setsockopt(fd, SOL_SOCKET, SO_KEEPALIVE, &val, sizeof(val)); + ++#ifdef SOL_TCP + val = 30; + setsockopt(fd, SOL_TCP, TCP_KEEPIDLE, &val, sizeof(val)); + +@@ -162,6 +163,7 @@ void cServer::NewClientConnected(int fd) + + val = 1; + setsockopt(fd, SOL_TCP, TCP_NODELAY, &val, sizeof(val)); ++#endif + + isyslog("VNSI: Client with ID %d connected: %s", m_IdCnt, cxSocket::ip2txt(sin.sin_addr.s_addr, sin.sin_port, buf)); + cConnection *connection = new cConnection(this, fd, m_IdCnt, cxSocket::ip2txt(sin.sin_addr.s_addr, sin.sin_port, buf)); diff --git a/multimedia/vdr-plugin-vnsiserver/pkg-descr b/multimedia/vdr-plugin-vnsiserver/pkg-descr new file mode 100644 index 000000000000..b9d2fe8ca489 --- /dev/null +++ b/multimedia/vdr-plugin-vnsiserver/pkg-descr @@ -0,0 +1,7 @@ +http://www.vdr-wiki.de/wiki/index.php/Vnsi-server-plugin + +VDR-Network-Streaming-Interface plugin (untested, currently used by +the XBMC pvr-testing2 branch which hasn't been ported to FreeBSD yet +at the time of writing.) + +WWW: http://www.vdr-portal.de/board/thread.php?threadid=95292 diff --git a/multimedia/vdr-plugin-vnsiserver/pkg-plist b/multimedia/vdr-plugin-vnsiserver/pkg-plist new file mode 100644 index 000000000000..ca3b139dc200 --- /dev/null +++ b/multimedia/vdr-plugin-vnsiserver/pkg-plist @@ -0,0 +1,5 @@ +lib/vdr/libvdr-vnsiserver.so.1.7.17 +@unexec if cmp -s %D/etc/vdr/plugins/vnsiserver/allowed_hosts.conf.sample %D/etc/vdr/plugins/vnsiserver/allowed_hosts.conf; then rm -f %D/etc/vdr/plugins/vnsiserver/allowed_hosts.conf; fi +etc/vdr/plugins/vnsiserver/allowed_hosts.conf.sample +@exec if [ ! -f %D/etc/vdr/plugins/vnsiserver/allowed_hosts.conf ] ; then cp -p %D/%F %B/allowed_hosts.conf; fi +@dirrmtry etc/vdr/plugins/vnsiserver |