aboutsummaryrefslogtreecommitdiff
path: root/comms
diff options
context:
space:
mode:
authorMartin Wilke <miwi@FreeBSD.org>2008-11-09 16:51:31 +0000
committerMartin Wilke <miwi@FreeBSD.org>2008-11-09 16:51:31 +0000
commit26873a40b354485bfda6cc20c12277cd4628adb6 (patch)
treefb54b4ae8af3c054c0a062d6eef3dda10efbb6d1 /comms
parent1ec8e7c7bb5a0a1bbf5784c8d3c3ab4ebfe896a0 (diff)
The overall goal of this project is to provide remote control service on Linux
through Bluetooth, InfraRed, Wi-Fi or just TCP/IP connection. anyRemote supports wide range of modern cell phones like Nokia, SonyEricsson, Motorola and others. It was developed as thin communication layer between Bluetooth (or IR, Wi-Fi) capabled phone and UNIX, and in principle could be configured to manage almost any software. WWW: http://anyremote.sourceforge.net/ PR: ports/128609 Submitted by: Alex Samorukov <samm at os2.kiev.ua>
Notes
Notes: svn path=/head/; revision=222617
Diffstat (limited to 'comms')
-rw-r--r--comms/Makefile1
-rw-r--r--comms/anyremote/Makefile41
-rw-r--r--comms/anyremote/distinfo3
-rw-r--r--comms/anyremote/files/opt-nodocs-patch15
-rw-r--r--comms/anyremote/files/patch-freebsd486
-rw-r--r--comms/anyremote/files/patch-getline209
-rw-r--r--comms/anyremote/pkg-descr11
-rw-r--r--comms/anyremote/pkg-plist292
8 files changed, 1058 insertions, 0 deletions
diff --git a/comms/Makefile b/comms/Makefile
index 3aca37863c99..a3a16047c249 100644
--- a/comms/Makefile
+++ b/comms/Makefile
@@ -5,6 +5,7 @@
SUBDIR += acfax
SUBDIR += aldo
+ SUBDIR += anyremote
SUBDIR += aprsd
SUBDIR += asmodem
SUBDIR += atslog
diff --git a/comms/anyremote/Makefile b/comms/anyremote/Makefile
new file mode 100644
index 000000000000..370d473ed379
--- /dev/null
+++ b/comms/anyremote/Makefile
@@ -0,0 +1,41 @@
+# New ports collection makefile for: anyremote
+# Date created: 2008-11-05
+# Whom: Alex Samorukov <samm@os2.kiev.ua>
+#
+# $FreeBSD$
+#
+
+PORTNAME= anyremote
+PORTVERSION= 4.11
+CATEGORIES= comms
+MASTER_SITES= SF
+
+MAINTAINER= samm@os2.kiev.ua
+COMMENT= Remote control service over Bluetooth,infrared or tcp/ip networking
+
+USE_AUTOTOOLS= automake:14 autoconf:262 libtool:15
+GNU_CONFIGURE= yes
+CONFIGURE_ENV= CPPFLAGS="-I${LOCALBASE}/include" \
+ LDFLAGS="-L${LOCALBASE}/lib"
+
+.if defined(NOPORTDOCS)
+EXTRA_PATCHES= ${FILESDIR}/opt-nodocs-patch
+.endif
+.if defined(WITHOUT_X11)
+CONFIGURE_ARGS+=--disable-xtest
+.else
+USE_XORG= x11 xtst
+.endif
+MAKE_ARGS+= LDFLAGS="-L${LOCALBASE}/lib"
+
+MAN1= anyremote.1
+MANCOMPRESSED= yes
+
+pre-configure:
+ cd ${WRKSRC} && ${AUTOMAKE} -a && ${AUTORECONF}
+pre-build:
+ cd ${WRKSRC} && ${MAKE} clean
+post-patch:
+ @${REINPLACE_CMD} -e 's|(datadir)/man/man1|(mandir)/man1|g' ${WRKSRC}/Makefile.am
+
+.include <bsd.port.mk>
diff --git a/comms/anyremote/distinfo b/comms/anyremote/distinfo
new file mode 100644
index 000000000000..77a11730ba3b
--- /dev/null
+++ b/comms/anyremote/distinfo
@@ -0,0 +1,3 @@
+MD5 (anyremote-4.11.tar.gz) = b4a856b3f95de57ce1c227c0f43eb0dd
+SHA256 (anyremote-4.11.tar.gz) = d0e411d1afacecd0f6732ed5454989434a039f172b599cbaaaacec783cfc63a8
+SIZE (anyremote-4.11.tar.gz) = 1457711
diff --git a/comms/anyremote/files/opt-nodocs-patch b/comms/anyremote/files/opt-nodocs-patch
new file mode 100644
index 000000000000..83be88dd5202
--- /dev/null
+++ b/comms/anyremote/files/opt-nodocs-patch
@@ -0,0 +1,15 @@
+--- Makefile.am 2008-10-16 21:00:58.000000000 +0200
++++ Makefile.am 2008-11-05 12:23:19.000000000 +0100
+@@ -24,12 +24,8 @@
+
+ install-data-local:
+ test -z $(DESTDIR)$(pkgdatadir) || mkdir -p -- . $(DESTDIR)$(pkgdatadir)
+- test -z $(DESTDIR)$(datadir)/doc/anyremote || mkdir -p -- . $(DESTDIR)$(datadir)/doc/anyremote
+ cp -r cfg-data $(DESTDIR)$(pkgdatadir)
+- cp -r doc-html ChangeLog README COPYING AUTHORS $(DESTDIR)$(datadir)/doc/anyremote/
+- find $(DESTDIR)$(pkgdatadir) $(DESTDIR)$(datadir)/doc/anyremote -type f -exec chmod 644 {} \;
+ chmod -R a+x $(DESTDIR)$(pkgdatadir)/cfg-data/Utils
+- find $(DESTDIR)$(pkgdatadir) $(DESTDIR)$(datadir)/doc/anyremote -type d -exec chmod 755 {} \;
+ test -z $(DESTDIR)$(datadir)/man/man1 || mkdir -p -- . $(DESTDIR)$(datadir)/man/man1
+ cp -r anyremote.1.gz $(DESTDIR)$(datadir)/man/man1
+ chmod 644 $(DESTDIR)$(datadir)/man/man1/anyremote.1.gz
diff --git a/comms/anyremote/files/patch-freebsd b/comms/anyremote/files/patch-freebsd
new file mode 100644
index 000000000000..009e7ec8b36a
--- /dev/null
+++ b/comms/anyremote/files/patch-freebsd
@@ -0,0 +1,486 @@
+diff -ur configure.in anyremote-4.11-fbsd/configure.in
+--- configure.in 2008-10-16 20:56:17.000000000 +0200
++++ configure.in 2008-10-31 13:09:34.000000000 +0100
+@@ -53,14 +53,31 @@
+ #AC_CONFIG_FILES([Makefile
+ # src/Makefile])
+
+-AC_ARG_ENABLE(bluez,
+- [ --disable-bluez disable bluez support])
++AC_CANONICAL_HOST
+
+-if test x"$enable_bluez" != xno; then
+- AC_CHECK_HEADERS([bluetooth/bluetooth.h], [], [echo "Can not find bluetooth.h ! Install it or use --disable-bluez";exit])
+- AR_EXTRAFLAGS="$AR_EXTRAFLAGS -DUSE_BT=1"
+- AR_EXTRALIBS="$AR_EXTRALIBS -lbluetooth"
+-fi
++case "$host_os" in
++linux*)
++ AC_ARG_ENABLE(bluez,
++ [ --disable-bluez disable bluez support])
++
++ if test x"$enable_bluez" != xno; then
++ AC_CHECK_HEADERS([bluetooth/bluetooth.h], [], [echo "Can not find bluetooth.h ! Install it or use --disable-bluez";exit])
++ AR_EXTRAFLAGS="$AR_EXTRAFLAGS -DUSE_BT=1"
++ AR_EXTRALIBS="$AR_EXTRALIBS -lbluetooth"
++ fi
++ AR_EXTRAFLAGS="$AR_EXTRAFLAGS -DHAVE_GETLINE=1"
++ ;;
++freebsd*)
++ AC_ARG_ENABLE(bluetooth,
++ [ --disable-bluetooth disable bluetooth support])
++
++ if test x"$enable_bluetooth" != xno; then
++ AC_CHECK_HEADERS([bluetooth.h], [], [echo "Can not find bluetooth.h ! Install it or use --disable-bluetooth";exit])
++ AR_EXTRAFLAGS="$AR_EXTRAFLAGS -DUSE_BT_FBSD=1"
++ AR_EXTRALIBS="$AR_EXTRALIBS -lbluetooth -lsdp"
++ fi
++ ;;
++esac
+
+ AC_ARG_ENABLE(xtext,
+ [ --disable-xtest disable xtest support])
+Only in anyremote-4.11-fbsd/: configure.in~
+Only in anyremote-4.11-fbsd/: configure.lineno
+diff -ur anyremote-4.11/src/Makefile.am anyremote-4.11-fbsd/src/Makefile.am
+--- src/Makefile.am 2008-09-29 20:54:38.000000000 +0200
++++ src/Makefile.am 2008-10-31 13:08:21.000000000 +0100
+@@ -19,7 +19,7 @@
+ #
+
+ bin_PROGRAMS = anyremote
+-anyremote_SOURCES = atsend.c btio.c main.c cmds.c parse.c utils.c xemulate.c conf.c atsend.h common.h btio.h common.h parse.h cmds.h utils.h xemulate.h conf.h
++anyremote_SOURCES = atsend.c btio.c main.c cmds.c parse.c utils.c xemulate.c conf.c atsend.h common.h btio.h common.h parse.h cmds.h utils.h xemulate.h conf.h getline.h getline.c
+ anyremote_LDFLAGS = @LDFLAGS@
+ anyremote_LDADD = @AR_EXTRALIBS@
+ AM_CFLAGS = @AR_EXTRAFLAGS@
+diff -ur anyremote-4.11/src/btio.c anyremote-4.11-fbsd/src/btio.c
+--- src/btio.c 2008-09-29 20:54:38.000000000 +0200
++++ src/btio.c 2008-11-01 20:04:02.000000000 +0100
+@@ -40,12 +40,19 @@
+ #include <netdb.h>
+
+ //#define USE_BT
++// #define USE_BT_FBSD
+
+ #ifdef USE_BT
+ #include <bluetooth/bluetooth.h>
+ #include <bluetooth/rfcomm.h>
+ #endif
+
++#ifdef USE_BT_FBSD
++#include <bluetooth.h>
++#include <sdp.h>
++#include <err.h>
++#endif
++
+ #include "btio.h"
+ #include "common.h"
+ #include "parse.h"
+@@ -576,6 +583,39 @@
+ }
+ #endif
+
++#ifdef USE_BT_FBSD
++void *session = NULL;
++uint32_t record;
++
++
++void sdpRegister(int port)
++{
++ int channel,service;
++ bdaddr_t bt_addr_any;
++ sdp_lan_profile_t lan;
++
++ channel = port;
++ service = SDP_SERVICE_CLASS_SERIAL_PORT;
++
++ session = sdp_open_local(NULL);
++ if (session == NULL)
++ errx(1, "Unable to create local SDP session");
++ if (sdp_error(session) != 0)
++ errx(1, "Unable to open local SDP session. %s (%d)",
++ strerror(sdp_error(session)), sdp_error(session));
++ memset(&lan, 0, sizeof(lan));
++ lan.server_channel = channel;
++
++ memcpy(&bt_addr_any, NG_HCI_BDADDR_ANY, sizeof(bt_addr_any));
++ if (sdp_register_service(session, service, &bt_addr_any,
++ (void *)&lan, sizeof(lan), &record) != 0) {
++ errx(1, "Unable to register LAN service with "
++ "local SDP daemon. %s (%d)",
++ strerror(sdp_error(session)), sdp_error(session));
++ }
++}
++#endif
++
+ void sdpDeregister()
+ {
+ #ifdef USE_BT
+@@ -585,6 +625,13 @@
+ //sdp_record_free(record);
+ }
+ #endif
++ #ifdef USE_BT_FBSD
++ if (session != NULL) {
++ sdp_unregister_service(session, record);
++ sdp_close(session);
++ session = NULL;
++ }
++ #endif
+ }
+
+ //
+@@ -598,11 +645,15 @@
+ #ifdef USE_BT
+ struct sockaddr_rc bt_addr;
+ #endif
++ #ifdef USE_BT_FBSD
++ struct sockaddr_rfcomm bt_addr;
++ #endif
+
+ struct sockaddr* socketaddr = NULL;
+
+ int addFamily = 0;
+ int proto = 0;
++ int sz;
+
+ if (sportfd) {
+ logger("ERROR", "socket was already opened");
+@@ -619,6 +670,10 @@
+ addFamily = PF_BLUETOOTH;
+ proto = BTPROTO_RFCOMM;
+ #endif
++ #ifdef USE_BT_FBSD
++ addFamily = PF_BLUETOOTH;
++ proto = BLUETOOTH_PROTO_RFCOMM;
++ #endif
+ } else if (type == SERVER_UX) {
+ addFamily = AF_UNIX;
+ proto = 0;
+@@ -654,10 +709,12 @@
+ tcp_addr.sin_port = htons(port);
+
+ socketaddr=(struct sockaddr *)&tcp_addr;
++ sz = sizeof(tcp_addr);
+
+ } else if (type == SERVER_BT){ // SERVER_BT
+ #ifdef USE_BT
+ memset((void *) &bt_addr, 0, sizeof(bt_addr));
++ sz = sizeof(bt_addr);
+
+ // bind socket to the specified port of the first available local bluetooth adapter
+ bt_addr.rc_family = AF_BLUETOOTH;
+@@ -673,8 +730,21 @@
+ sdpRegister(port);
+ sprintf(tmp, "registered SP for channel %i", port);
+ logger("INFO", tmp);
++ socketaddr=(struct sockaddr *)&bt_addr;
++ #endif
++
++ #ifdef USE_BT_FBSD
++ memset(&bt_addr, 0, sizeof(bt_addr));
+
++ bt_addr.rfcomm_len = sizeof(bt_addr);
++ bt_addr.rfcomm_family = AF_BLUETOOTH;
++ bt_addr.rfcomm_channel = (uint8_t) port;;
++ sdpRegister(port);
++ sprintf(tmp, "registered SP for channel %i", port);
++ logger("INFO", tmp);
++
+ socketaddr=(struct sockaddr *)&bt_addr;
++ sz = sizeof(bt_addr);
+ #endif
+ } else if (type == SERVER_UX && path != NULL){
+
+@@ -683,16 +753,16 @@
+ strncpy(un_addr.sun_path, path, sizeof un_addr.sun_path - 1);
+ printf("ERROR: SOCKET %s\n", path);
+ socketaddr=(struct sockaddr *)&un_addr;
++ sz = sizeof(un_addr);
+
+ } else {
+ logger("ERROR", "incorrect input 2");
+ return -1;
+ }
+
+- if (bind(sportfd, (struct sockaddr *) socketaddr, sizeof(*socketaddr)) < 0) {
++ if (bind(sportfd, (struct sockaddr *) socketaddr, sz) < 0) {
+ logger("ERROR", "on binding");
+ printf("ERROR: on binding %d->%s\n", errno, strerror(errno));
+-
+ return -1;
+ }
+
+@@ -735,11 +805,15 @@
+ bdaddr_t ba;
+ #endif
+
++ #ifdef USE_BT_FBSD
++ struct sockaddr_rfcomm bt_addr;
++ #endif
++
+ logger("INFO", "listenAndAcceptSocketConn");
+ cnt = 0;
+
+ if (type == SERVER_BT) {
+- #ifdef USE_BT
++ #if defined(USE_BT) || defined(USE_BT_FBSD)
+ socketaddr=(struct sockaddr *)&bt_addr;
+ sz = sizeof(bt_addr);
+ #endif
+@@ -789,7 +863,6 @@
+ #ifdef USE_BT
+ if (type == SERVER_BT) {
+ baswap(&ba, &bt_addr.rc_bdaddr);
+-
+ if (btAddress) {
+ free(btAddress);
+ }
+@@ -799,6 +872,17 @@
+ logger("INFO", tmp);
+ }
+ #endif
++ #ifdef USE_BT_FBSD
++ if (type == SERVER_BT) {
++ if (btAddress) {
++ free(btAddress);
++ }
++ btAddress = strdup(bt_ntoa(&bt_addr.rfcomm_bdaddr, NULL));
++
++ sprintf(tmp, "listenAndAcceptSocketConn: remote BT address is %s", btAddress);
++ logger("INFO", tmp);
++ }
++ #endif
+
+ break;
+ }
+Only in anyremote-4.11-fbsd/src: btio.c~
+diff -ur anyremote-4.11/src/cmds.c anyremote-4.11-fbsd/src/cmds.c
+--- src/cmds.c 2008-10-01 20:23:20.000000000 +0200
++++ src/cmds.c 2008-10-31 11:29:24.000000000 +0100
+@@ -39,6 +39,9 @@
+ #include "parse.h"
+ #include "utils.h"
+ #include "xemulate.h"
++#ifndef HAVE_GETLINE
++ #include "getline.h"
++#endif
+
+ extern void closePort(int final);
+ extern int isConnected;
+Only in anyremote-4.11-fbsd/src: cmds.c~
+Only in anyremote-4.11-fbsd/src: fileManager.cfg
+Only in anyremote-4.11-fbsd/src: getline.c
+Only in anyremote-4.11-fbsd/src: getline.c~
+Only in anyremote-4.11-fbsd/src: getline.h
+Only in anyremote-4.11-fbsd/src: getline.h~
+diff -ur anyremote-4.11/src/main.c anyremote-4.11-fbsd/src/main.c
+--- src/main.c 2008-10-16 20:59:27.000000000 +0200
++++ src/main.c 2008-11-01 20:33:35.000000000 +0100
+@@ -32,6 +32,9 @@
+ #include <sys/wait.h>
+ #include <time.h>
+ #include <unistd.h>
++#ifdef __FreeBSD__
++ #include <signal.h>
++#endif
+
+ #include "atsend.h"
+ #include "btio.h"
+@@ -46,6 +49,8 @@
+ #define ALARM_CLEAN 0
+ #define ALARM_CHECK 1
+
++extern CONF conf;
++
+ static void mainRoutine (void);
+ static int isBemusedCommand(char *cmd);
+ static int isInpLircCommand(char *cmd);
+@@ -201,6 +206,13 @@
+ }
+ initialized++;
+ }
++
++ // setgid
++ if(conf.uid && getuid()==0){
++ DEBUG2("setuid/setgid %d,%d",conf.uid,conf.gid);
++ setgid(conf.gid);
++ setuid(conf.uid);
++ }
+ return 1;
+ }
+
+@@ -216,6 +228,9 @@
+ closedir(d);
+ } else {
+ mkdir(dd, S_IRWXU);
++ if(getuid()==0 && conf.uid) { // do not create as superuser
++ chown(dd,conf.uid,conf.gid);
++ }
+ }
+ }
+
+@@ -309,8 +324,6 @@
+ }
+ }
+
+- createDataDir();
+-
+ if (argv[1] && (strcmp(argv[1],"-h")==0 || strcmp(argv[1],"--help")==0)) {
+ //Just print help and exit
+ printHelp();
+@@ -334,7 +347,8 @@
+ freeCfg();
+ exit(1);
+ }
+-
++
++ createDataDir();
+ initLog();
+
+ // Not to core dump if connection will close
+Only in anyremote-4.11-fbsd/src: main.c~
+Only in anyremote-4.11-fbsd/src: make.sh
+diff -ur anyremote-4.11/src/parse.c anyremote-4.11-fbsd/src/parse.c
+--- src/parse.c 2008-10-06 15:19:34.000000000 +0200
++++ src/parse.c 2008-11-01 19:58:30.000000000 +0100
+@@ -50,7 +50,7 @@
+ #define REGEX_TIMER "[[:space:]]*([^[:space:]]+)[[:space:]]*,[[:space:]]*([[:digit:]]*)[[:space:]]*,[[:space:]]*([[:digit:]]*)[[:space:]]*$|[[:space:]]*([^[:space:]]+)[[:space:]]*,[[:space:]]*(cancel|pause|continue)"
+ #define REGEX_MAKE "[[:space:]]*(remote|mode|var)[[:space:]]*,[[:space:]]*(.*)[[:space:]]*|[[:space:]]*(exit|flush|disconnect|none)[[:space:]]*"
+
+-#define REGEX_SET_TL "[[:space:]]*(fg|bg|font|select)[[:space:]]*,(.*)|[[:space:]]*(add|replace)[[:space:]]*,[[:space:]]*([^[:space:]]{1}[^,]*[^[:space:]]{1})[[:space:]]*,[[:space:]]*(.*)|[[:space:]]*(close)[[:space:]]*,[[:space:]]**(clear)[[:space:]]*|[[:space:]]*(clear|close|show)[[:space:]]*"
++#define REGEX_SET_TL "[[:space:]]*(fg|bg|font|select)[[:space:]]*,(.*)|[[:space:]]*(add|replace)[[:space:]]*,[[:space:]]*([^[:space:]]{1}[^,]*[^[:space:]]{1})[[:space:]]*,[[:space:]]*(.*)|[[:space:]]*(close)[[:space:]]*,[[:space:]]*(clear)[[:space:]]*|[[:space:]]*(clear|close|show)[[:space:]]*"
+ #define REGEX_SET_MN "[[:space:]]*(add|replace)[[:space:]]*,(.*)|[[:space:]]*(clear)[[:space:]]*"
+ #define REGEX_SET_WM "[[:space:]]*(icon|window)[[:space:]]*,(.*)|[[:space:]]*(remove_all|show|close|cursor|nocursor|dynamic_cursor)[[:space:]]*|[[:space:]]*(set_cursor),[[:space:]]*(.*)[[:space:]]*"
+ #define REGEX_SET_FM "[[:space:]]*(add|replace|select)[[:space:]]*,[[:space:]]*(left|right)[[:space:]]*,[[:space:]]*(.*)|[[:space:]]*(close|show)[[:space:]]*"
+@@ -85,7 +85,9 @@
+ MODEL_DEFAULT, // Model
+ NULL, // Cfg. dir
+ -1, // Front-end port
+- 0}; // Work with anyremote2html
++ 0, // Work with anyremote2html
++ 0, // set uid
++ 0}; // set gid
+
+ type_key* findExact(mode *mode, char *key)
+ {
+@@ -216,6 +218,9 @@
+ conf.http = 1;
+ } else if (strcmp(argv[i],"--autoconnect")==0 || strcmp(argv[i],"-a")==0) {
+ conf.autoConnect = 1;
++ } else if (strcmp(argv[i],"--user")==0 || strcmp(argv[i],"-u")==0) {
++ if(getUidGid(argv[++i], &conf.uid, &conf.gid)!=EXIT_OK)
++ printf("WARNING: bad username %s\n", argv[i]);
+ } else if (strcmp(argv[i],"-f")==0) {
+ ++i;
+ continue; // already processed this parameter
+Only in anyremote-4.11-fbsd/src: parse.c~
+diff -ur anyremote-4.11/src/parse.h anyremote-4.11-fbsd/src/parse.h
+--- src/parse.h 2008-09-29 20:54:38.000000000 +0200
++++ src/parse.h 2008-11-01 19:47:18.000000000 +0100
+@@ -23,6 +23,8 @@
+ #define _PARSE_H_ 1
+
+ #include "common.h"
++#include <sys/types.h>
++#include <unistd.h>
+
+ #define CFGFILE "/.anyremote.cfg"
+
+@@ -241,6 +243,8 @@
+ char* cfgDir;
+ int frontEnd;
+ int http;
++ uid_t uid;
++ gid_t gid;
+ } CONF;
+
+
+Only in anyremote-4.11-fbsd/src: parse.h~
+diff -ur anyremote-4.11/src/utils.c anyremote-4.11-fbsd/src/utils.c
+--- src/utils.c 2008-10-20 20:13:39.000000000 +0200
++++ src/utils.c 2008-11-01 20:42:28.000000000 +0100
+@@ -23,12 +23,16 @@
+ #include <stdlib.h>
+ #include <string.h>
+ #include <time.h>
++#include <sys/types.h>
++#include <pwd.h>
+
+ #include "common.h"
+ #include "utils.h"
+ #include "conf.h"
+
++
+ extern char tmp[MAXMAXLEN];
++extern CONF conf;
+
+ // Some globals
+
+@@ -91,7 +95,11 @@
+ FILE *fplog = fopen(logfile, "w");
+ if (fplog) {
+ fclose(fplog);
+- }
++ }
++ if(getuid()==0 && conf.uid) { // do not open file as superuser
++ chown(logfile,conf.uid,conf.gid);
++ }
++
+ printConf();
+ }
+ }
+@@ -451,7 +459,9 @@
+ printf(" -n do not send any AT+CKPD command to the phone\n");
+ printf(" -a reconnect automatically in case of connection failure\n");
+ printf(" -fe <port> work as backend for GUI frontend. Use specified port to connect to frontend.\n");
+- printf(" -http tune work with anyremote2html\n\n");
++ printf(" -http tune work with anyremote2html\n");
++ printf(" -u|--user <username> causes to run as a user other than root. \n\n");
++
+ }
+
+ int flushData()
+@@ -486,4 +496,21 @@
+ flushAliases = NULL;
+ }
+
++int getUidGid(char *username, uid_t *uid, gid_t *gid) {
++ /* Set uid and gid to the preferred user (found in setuid.h). Can either be
++ * numeric or a string, found in /etc/passwd. */
++ struct passwd *pw;
++
++ if ((pw = getpwnam(username))) {
++ // Name exists
++ *uid = pw->pw_uid;
++ *gid = pw->pw_gid;
++ return EXIT_OK;
++ }
++ /* something Bad happened, so send back an error */
++ return EXIT_NOK;
++}
++
++
++
+ //////////////////////////////////////////////////////////////////////////////////
+Only in anyremote-4.11-fbsd/src: utils.c~
+diff -ur anyremote-4.11/src/utils.h anyremote-4.11-fbsd/src/utils.h
+--- src/utils.h 2008-09-29 20:54:38.000000000 +0200
++++ src/utils.h 2008-11-01 19:52:34.000000000 +0100
+@@ -23,6 +23,8 @@
+ #define _UTILS_H
+
+ #include "parse.h"
++#include <sys/types.h>
++#include <pwd.h>
+
+ #define LOGFILE "/anyremote.log"
+
+@@ -78,4 +80,6 @@
+ void setResFile (void);
+ char* getResFile (void);
+
++int getUidGid(char *username, uid_t *uid, gid_t *gid) ;
++
+ #endif
diff --git a/comms/anyremote/files/patch-getline b/comms/anyremote/files/patch-getline
new file mode 100644
index 000000000000..63fae1653bb5
--- /dev/null
+++ b/comms/anyremote/files/patch-getline
@@ -0,0 +1,209 @@
+diff -urN getline1/getline.c getline2/getline.c
+--- src/getline.c 1970-01-01 01:00:00.000000000 +0100
++++ src/getline.c 2008-10-31 13:10:57.000000000 +0100
+@@ -0,0 +1,176 @@
++/* getline.c -- Replacement for GNU C library function getline
++
++Copyright (C) 1993 Free Software Foundation, Inc.
++
++This program is free software; you can redistribute it and/or
++modify it under the terms of the GNU General Public License as
++published by the Free Software Foundation; either version 2 of the
++License, or (at your option) any later version.
++
++This program is distributed in the hope that it will be useful, but
++WITHOUT ANY WARRANTY; without even the implied warranty of
++MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
++General Public License for more details. */
++
++/* Written by Jan Brittenson, bson@gnu.ai.mit.edu. */
++
++#ifndef HAVE_GETLINE
++#ifdef HAVE_CONFIG_H
++#include <config.h>
++#endif
++
++#include <sys/types.h>
++#include <stdio.h>
++#include <assert.h>
++#include <errno.h>
++#include "getline.h"
++
++#if STDC_HEADERS
++#include <stdlib.h>
++#else
++char *malloc (), *realloc ();
++#endif
++
++/* Always add at least this many bytes when extending the buffer. */
++#define MIN_CHUNK 64
++
++/* Read up to (and including) a TERMINATOR from STREAM into *LINEPTR
++ + OFFSET (and null-terminate it). If LIMIT is non-negative, then
++ read no more than LIMIT chars.
++
++ *LINEPTR is a pointer returned from malloc (or NULL), pointing to
++ *N characters of space. It is realloc'd as necessary.
++
++ Return the number of characters read (not including the null
++ terminator), or -1 on error or EOF. On a -1 return, the caller
++ should check feof(), if not then errno has been set to indicate the
++ error. */
++
++int
++getstr (lineptr, n, stream, terminator, offset, limit)
++ char **lineptr;
++ size_t *n;
++ FILE *stream;
++ int terminator;
++ int offset;
++ int limit;
++{
++ int nchars_avail; /* Allocated but unused chars in *LINEPTR. */
++ char *read_pos; /* Where we're reading into *LINEPTR. */
++ int ret;
++
++ if (!lineptr || !n || !stream)
++ {
++ errno = EINVAL;
++ return -1;
++ }
++
++ if (!*lineptr)
++ {
++ *n = MIN_CHUNK;
++ *lineptr = malloc (*n);
++ if (!*lineptr)
++ {
++ errno = ENOMEM;
++ return -1;
++ }
++ *lineptr[0] = '\0';
++ }
++
++ nchars_avail = *n - offset;
++ read_pos = *lineptr + offset;
++
++ for (;;)
++ {
++ int save_errno;
++ register int c;
++
++ if (limit == 0)
++ break;
++ else
++ {
++ c = getc (stream);
++
++ /* If limit is negative, then we shouldn't pay attention to
++ it, so decrement only if positive. */
++ if (limit > 0)
++ limit--;
++ }
++
++ save_errno = errno;
++
++ /* We always want at least one char left in the buffer, since we
++ always (unless we get an error while reading the first char)
++ NUL-terminate the line buffer. */
++
++ assert((*lineptr + *n) == (read_pos + nchars_avail));
++ if (nchars_avail < 2)
++ {
++ if (*n > MIN_CHUNK)
++ *n *= 2;
++ else
++ *n += MIN_CHUNK;
++
++ nchars_avail = *n + *lineptr - read_pos;
++ *lineptr = realloc (*lineptr, *n);
++ if (!*lineptr)
++ {
++ errno = ENOMEM;
++ return -1;
++ }
++ read_pos = *n - nchars_avail + *lineptr;
++ assert((*lineptr + *n) == (read_pos + nchars_avail));
++ }
++
++ if (ferror (stream))
++ {
++ /* Might like to return partial line, but there is no
++ place for us to store errno. And we don't want to just
++ lose errno. */
++ errno = save_errno;
++ return -1;
++ }
++
++ if (c == EOF)
++ {
++ /* Return partial line, if any. */
++ if (read_pos == *lineptr)
++ return -1;
++ else
++ break;
++ }
++
++ *read_pos++ = c;
++ nchars_avail--;
++
++ if (c == terminator)
++ /* Return the line. */
++ break;
++ }
++
++ /* Done - NUL terminate and return the number of chars read. */
++ *read_pos = '\0';
++
++ ret = read_pos - (*lineptr + offset);
++ return ret;
++}
++
++int
++getline (lineptr, n, stream)
++ char **lineptr;
++ size_t *n;
++ FILE *stream;
++{
++ return getstr (lineptr, n, stream, '\n', 0, GETLINE_NO_LIMIT);
++}
++
++int
++getline_safe (lineptr, n, stream, limit)
++ char **lineptr;
++ size_t *n;
++ FILE *stream;
++ int limit;
++{
++ return getstr (lineptr, n, stream, '\n', 0, limit);
++}
++#endif /* HAVE_GETLINE */
+diff -urN getline1/getline.h getline2/getline.h
+--- src/getline.h 1970-01-01 01:00:00.000000000 +0100
++++ src/getline.h 2008-10-31 13:10:51.000000000 +0100
+@@ -0,0 +1,25 @@
++#ifndef HAVE_GETLINE
++#ifndef _getline_h_
++#define _getline_h_ 1
++
++#include <stdio.h>
++
++#if defined (__GNUC__) || (defined (__STDC__) && __STDC__)
++#define __PROTO(args) args
++#else
++#define __PROTO(args) ()
++#endif /* GCC. */
++
++#define GETLINE_NO_LIMIT -1
++
++int
++ getline __PROTO ((char **_lineptr, size_t *_n, FILE *_stream));
++int
++ getline_safe __PROTO ((char **_lineptr, size_t *_n, FILE *_stream,
++ int limit));
++int
++ getstr __PROTO ((char **_lineptr, size_t *_n, FILE *_stream,
++ int _terminator, int _offset, int limit));
++
++#endif /* _getline_h_ */
++#endif /* HAVE_GETLINE */
diff --git a/comms/anyremote/pkg-descr b/comms/anyremote/pkg-descr
new file mode 100644
index 000000000000..311ad042b381
--- /dev/null
+++ b/comms/anyremote/pkg-descr
@@ -0,0 +1,11 @@
+The overall goal of this project is to provide remote control service on Linux
+through Bluetooth, InfraRed, Wi-Fi or just TCP/IP connection.
+
+anyRemote supports wide range of modern cell phones like Nokia, SonyEricsson,
+Motorola and others.
+
+It was developed as thin communication layer between Bluetooth (or IR, Wi-Fi)
+capabled phone and UNIX, and in principle could be configured to manage almost
+any software.
+
+WWW: http://anyremote.sourceforge.net/
diff --git a/comms/anyremote/pkg-plist b/comms/anyremote/pkg-plist
new file mode 100644
index 000000000000..3d16a03d68b6
--- /dev/null
+++ b/comms/anyremote/pkg-plist
@@ -0,0 +1,292 @@
+@comment $FreeBSD$
+bin/anyremote
+%%DATADIR%%/cfg-data/Server-mode/kuickshow.cfg
+%%DATADIR%%/cfg-data/Server-mode/comix.cfg
+%%DATADIR%%/cfg-data/Server-mode/freevo.cfg
+%%DATADIR%%/cfg-data/Server-mode/aqualung.cfg
+%%DATADIR%%/cfg-data/Server-mode/kview.cfg
+%%DATADIR%%/cfg-data/Server-mode/gthumb.cfg
+%%DATADIR%%/cfg-data/Server-mode/xfmedia.cfg
+%%DATADIR%%/cfg-data/Server-mode/mouse.cfg
+%%DATADIR%%/cfg-data/Server-mode/kaffeine_dvbt.cfg
+%%DATADIR%%/cfg-data/Server-mode/fileManager2.cfg
+%%DATADIR%%/cfg-data/Server-mode/evince.cfg
+%%DATADIR%%/cfg-data/Server-mode/customizeClient3.cfg
+%%DATADIR%%/cfg-data/Server-mode/xine.cfg
+%%DATADIR%%/cfg-data/Server-mode/customizeClient5.cfg
+%%DATADIR%%/cfg-data/Server-mode/ooimpress.cfg
+%%DATADIR%%/cfg-data/Server-mode/imageViewer.cfg
+%%DATADIR%%/cfg-data/Server-mode/keyboard.cfg
+%%DATADIR%%/cfg-data/Server-mode/all-in-one.cfg
+%%DATADIR%%/cfg-data/Server-mode/gmusicbrowser.cfg
+%%DATADIR%%/cfg-data/Server-mode/fileManager.cfg
+%%DATADIR%%/cfg-data/Server-mode/mpd.cfg
+%%DATADIR%%/cfg-data/Server-mode/rssReader.cfg
+%%DATADIR%%/cfg-data/Server-mode/fileManager3.cfg
+%%DATADIR%%/cfg-data/Server-mode/keyjnote.cfg
+%%DATADIR%%/cfg-data/Server-mode/kpdf.cfg
+%%DATADIR%%/cfg-data/Server-mode/xmms2.cfg
+%%DATADIR%%/cfg-data/Server-mode/amarok-v2.cfg
+%%DATADIR%%/cfg-data/Server-mode/kaboodle.cfg
+%%DATADIR%%/cfg-data/Server-mode/juk.cfg
+%%DATADIR%%/cfg-data/Server-mode/quodlibet.cfg
+%%DATADIR%%/cfg-data/Server-mode/noatun.cfg
+%%DATADIR%%/cfg-data/Server-mode/gnomeradio.cfg
+%%DATADIR%%/cfg-data/Server-mode/customizeClient2.cfg
+%%DATADIR%%/cfg-data/Server-mode/elisa.cfg
+%%DATADIR%%/cfg-data/Server-mode/xmms.cfg
+%%DATADIR%%/cfg-data/Server-mode/kmplayer.cfg
+%%DATADIR%%/cfg-data/Server-mode/iconUpload.cfg
+%%DATADIR%%/cfg-data/Server-mode/banshee.cfg
+%%DATADIR%%/cfg-data/Server-mode/rhythmbox.cfg
+%%DATADIR%%/cfg-data/Server-mode/autolock.cfg
+%%DATADIR%%/cfg-data/Server-mode/mplayer.cfg
+%%DATADIR%%/cfg-data/Server-mode/totem.cfg
+%%DATADIR%%/cfg-data/Server-mode/xdtv.cfg
+%%DATADIR%%/cfg-data/Server-mode/kmid.cfg
+%%DATADIR%%/cfg-data/Server-mode/amarok.cfg
+%%DATADIR%%/cfg-data/Server-mode/adminExample.cfg
+%%DATADIR%%/cfg-data/Server-mode/customizeClient.cfg
+%%DATADIR%%/cfg-data/Server-mode/nokia-e70.cfg
+%%DATADIR%%/cfg-data/Server-mode/customizeClient4.cfg
+%%DATADIR%%/cfg-data/Server-mode/nokia-e61.cfg
+%%DATADIR%%/cfg-data/Server-mode/kaffeine-v2.cfg
+%%DATADIR%%/cfg-data/Server-mode/bmp.cfg
+%%DATADIR%%/cfg-data/Server-mode/sound.cfg
+%%DATADIR%%/cfg-data/Server-mode/kdetv.cfg
+%%DATADIR%%/cfg-data/Server-mode/kdialog.cfg
+%%DATADIR%%/cfg-data/Server-mode/vlc.cfg
+%%DATADIR%%/cfg-data/Server-mode/kscd.cfg
+%%DATADIR%%/cfg-data/Server-mode/multimode.cfg
+%%DATADIR%%/cfg-data/Server-mode/all-in-one2.cfg
+%%DATADIR%%/cfg-data/Server-mode/moc.cfg
+%%DATADIR%%/cfg-data/Server-mode/smplayer.cfg
+%%DATADIR%%/cfg-data/Server-mode/audacious.cfg
+%%DATADIR%%/cfg-data/Server-mode/tvtime.cfg
+%%DATADIR%%/cfg-data/Server-mode/amarok-v3.cfg
+%%DATADIR%%/cfg-data/Server-mode/winManager.cfg
+%%DATADIR%%/cfg-data/Server-mode/myth-tv.cfg
+%%DATADIR%%/cfg-data/Server-mode/gwenview.cfg
+%%DATADIR%%/cfg-data/Server-mode/kplayer.cfg
+%%DATADIR%%/cfg-data/Server-mode/kopete.cfg
+%%DATADIR%%/cfg-data/Server-mode/decibel.cfg
+%%DATADIR%%/cfg-data/Server-mode/kaffeine.cfg
+%%DATADIR%%/cfg-data/Server-mode/listen.cfg
+%%DATADIR%%/cfg-data/Server-mode/exaile.cfg
+%%DATADIR%%/cfg-data/Server-mode/banshee-v2.cfg
+%%DATADIR%%/cfg-data/Utils/gradient.png
+%%DATADIR%%/cfg-data/Utils/all-in-1.py
+%%DATADIR%%/cfg-data/Utils/xmms_is_playing
+%%DATADIR%%/cfg-data/Bemused-emulation/exaile.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/juk.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/quodlibet.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/noatun.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/xmms.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/rhythmbox.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/totem.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/template.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/amarok.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/kdetv.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/kscd.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/tvtime.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/kplayer.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/kaffeine.cfg
+%%DATADIR%%/cfg-data/Bemused-emulation/mpd.cfg
+%%DATADIR%%/cfg-data/AT-mode/kuickshow.cfg
+%%DATADIR%%/cfg-data/AT-mode/aqualung.cfg
+%%DATADIR%%/cfg-data/AT-mode/kview.cfg
+%%DATADIR%%/cfg-data/AT-mode/xfmedia.cfg
+%%DATADIR%%/cfg-data/AT-mode/mouse.cfg
+%%DATADIR%%/cfg-data/AT-mode/kdialog.se.cfg
+%%DATADIR%%/cfg-data/AT-mode/keyboard.cfg
+%%DATADIR%%/cfg-data/AT-mode/all-in-one.cfg
+%%DATADIR%%/cfg-data/AT-mode/xineForDvd.cfg
+%%DATADIR%%/cfg-data/AT-mode/gmusicbrowser.cfg
+%%DATADIR%%/cfg-data/AT-mode/mpd.cfg
+%%DATADIR%%/cfg-data/AT-mode/juk.cfg
+%%DATADIR%%/cfg-data/AT-mode/quodlibet.cfg
+%%DATADIR%%/cfg-data/AT-mode/noatun.cfg
+%%DATADIR%%/cfg-data/AT-mode/kdialog.sagem.cfg
+%%DATADIR%%/cfg-data/AT-mode/elisa.cfg
+%%DATADIR%%/cfg-data/AT-mode/xmms.cfg
+%%DATADIR%%/cfg-data/AT-mode/kmplayer.cfg
+%%DATADIR%%/cfg-data/AT-mode/kdialog.motorola.cfg
+%%DATADIR%%/cfg-data/AT-mode/banshee.cfg
+%%DATADIR%%/cfg-data/AT-mode/rhythmbox.cfg
+%%DATADIR%%/cfg-data/AT-mode/bmp.cfg
+%%DATADIR%%/cfg-data/AT-mode/autolock.cfg
+%%DATADIR%%/cfg-data/AT-mode/totem.cfg
+%%DATADIR%%/cfg-data/AT-mode/xdtv.cfg
+%%DATADIR%%/cfg-data/AT-mode/amarok.cfg
+%%DATADIR%%/cfg-data/AT-mode/sound.cfg
+%%DATADIR%%/cfg-data/AT-mode/kdetv.cfg
+%%DATADIR%%/cfg-data/AT-mode/kdialog.cfg
+%%DATADIR%%/cfg-data/AT-mode/kscd.cfg
+%%DATADIR%%/cfg-data/AT-mode/multimode.cfg
+%%DATADIR%%/cfg-data/AT-mode/moc.cfg
+%%DATADIR%%/cfg-data/AT-mode/audacious.cfg
+%%DATADIR%%/cfg-data/AT-mode/tvtime.cfg
+%%DATADIR%%/cfg-data/AT-mode/kplayer.cfg
+%%DATADIR%%/cfg-data/AT-mode/kdialog.siemens.cfg
+%%DATADIR%%/cfg-data/AT-mode/kaffeine.cfg
+%%DATADIR%%/cfg-data/AT-mode/listen.cfg
+%%DATADIR%%/cfg-data/AT-mode/exaile.cfg
+%%DATADIR%%/cfg-data/AT-mode/freevo.cfg
+@dirrm %%DATADIR%%/cfg-data/AT-mode
+@dirrm %%DATADIR%%/cfg-data/Bemused-emulation
+@dirrm %%DATADIR%%/cfg-data/Server-mode
+@dirrm %%DATADIR%%/cfg-data/Utils
+@dirrm %%DATADIR%%/cfg-data
+@dirrm %%DATADIR%%
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/jc/jc-menu.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/jc/fileManager2.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/jc/fileManager3.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/jc/amarok-16.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/jc/banshee-v2.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/jc/fileManager.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/jc/amarok.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/jc/amarok-v2.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/jc/banshee.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-blue.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-blue-bottom.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/question.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-red-bottom.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-green-top.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-red-top.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/yes.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-yellow-bottom.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-yellow.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-old.xcf
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/no.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-yellow-top.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-navigation-off.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-green-bottom.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bullet-blue.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-foot.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar.xcf
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-gray.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-green.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-gray-bottom.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-blue-top.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-navigation-on.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-gray-top.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/img/bg-sidebar-red.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/prev.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/question.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/play.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/mute.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/vol_down.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/folder.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/default.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/no.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/stop.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/eject.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/vol_up.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/up.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/rewind.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/down.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/launch.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/forward.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/left.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/minus.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/right.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/fullscreen.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/pause.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/file.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/view_tree.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/fit.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/click_icon.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/refresh.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/exit.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/next.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/plus.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/icons/info.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/client-text.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/ganyremote1.jpg
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/master.css
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/ganyremote-devdet.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/client-list.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/anyremote32.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/view-screen.jpg
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/default.css
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/anyRemote32.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/ganyremote2.jpg
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/ganyremote-tray.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/kanyremote-devbr.jpg
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/anyRemote.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/kanyremote2.jpg
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/anyremote16.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/kanyremote-devdet.jpg
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/logo-head.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/spacer.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/anyremote256.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/anyremote22.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/anyremote24.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/client-control-menu.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/ganyremote3.jpg
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/client-text-menu.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/client-test.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/any1.jpg
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/logo-detail.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/nothing.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/logo-favicon.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/anyRemote16.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/client-list-menu.png
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/any3.jpg
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/ganyremote-devbr.jpg
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/data/any6.jpg
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/man.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/dcop.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/cfg-howto.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/conf-server-ex.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/conf-server.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/setup-at.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/use.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/k-shots.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/set.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/bemused.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/g-shots.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/set-fm.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/set-parameter.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/thanks.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/ev-handlers.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/set-menu.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/index.html.dup
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/conf-at.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/set-icons.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/install.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/dload.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/devices.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/contacts.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/vars.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/ckpd-emulation.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/mode.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/index.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/set-text.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/setup-server.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/set-list.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/pre-setup.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/faq.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/set-window.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/docs.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/web.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/pre.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/frontend.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/ir.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/emulate.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/use-jc.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/phones.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/conf-at-ex.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/lirc.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/make.html
+%%PORTDOCS%%%%DOCSDIR%%/doc-html/event.html
+%%PORTDOCS%%%%DOCSDIR%%/AUTHORS
+%%PORTDOCS%%%%DOCSDIR%%/COPYING
+%%PORTDOCS%%%%DOCSDIR%%/README
+%%PORTDOCS%%%%DOCSDIR%%/ChangeLog
+%%PORTDOCS%%@dirrm %%DOCSDIR%%/doc-html/data/jc
+%%PORTDOCS%%@dirrm %%DOCSDIR%%/doc-html/data/img
+%%PORTDOCS%%@dirrm %%DOCSDIR%%/doc-html/data/icons
+%%PORTDOCS%%@dirrm %%DOCSDIR%%/doc-html/data
+%%PORTDOCS%%@dirrm %%DOCSDIR%%/doc-html
+%%PORTDOCS%%@dirrm %%DOCSDIR%%