diff options
-rw-r--r-- | devel/gamin/Makefile | 68 | ||||
-rw-r--r-- | devel/gamin/distinfo | 2 | ||||
-rw-r--r-- | devel/gamin/files/patch-libgamin_gam_api.c | 119 | ||||
-rw-r--r-- | devel/gamin/files/patch-python_Makefile.in | 20 | ||||
-rw-r--r-- | devel/gamin/files/patch-server__gam_node.h | 11 | ||||
-rw-r--r-- | devel/gamin/files/patch-server__gam_subscription.c | 11 | ||||
-rw-r--r-- | devel/gamin/files/patch-server__gam_subscription.h | 11 | ||||
-rw-r--r-- | devel/gamin/files/patch-server_gam_channel.c | 127 | ||||
-rw-r--r-- | devel/gamin/files/patch-server_gam_eq.c | 11 | ||||
-rw-r--r-- | devel/gamin/files/patch-server_gam_fs.c | 161 | ||||
-rw-r--r-- | devel/gamin/files/patch-server_gam_kqueue.c | 356 | ||||
-rw-r--r-- | devel/gamin/files/patch-server_gam_node.c | 19 | ||||
-rw-r--r-- | devel/gamin/files/patch-server_gam_poll_basic.c | 11 | ||||
-rw-r--r-- | devel/gamin/files/patch-server_gam_server.c | 40 | ||||
-rw-r--r-- | devel/gamin/files/patch-tests_testing.c | 27 | ||||
-rw-r--r-- | devel/gamin/pkg-descr | 8 | ||||
-rw-r--r-- | devel/gamin/pkg-message | 26 | ||||
-rw-r--r-- | devel/gamin/pkg-plist | 12 |
18 files changed, 0 insertions, 1040 deletions
diff --git a/devel/gamin/Makefile b/devel/gamin/Makefile deleted file mode 100644 index 26e472bae..000000000 --- a/devel/gamin/Makefile +++ /dev/null @@ -1,68 +0,0 @@ -# ports collection makefile for: gamin -# Date created: 24 March 2005 -# Whom: Joe Marcus Clarke <marcus@FreeBSD.org> -# -# $FreeBSD$ -# $MCom: ports/devel/gamin/Makefile,v 1.10 2012/06/29 08:09:36 kwm Exp $ -# - -PORTNAME= gamin -PORTVERSION= 0.1.10 -PORTREVISION?= 6 -CATEGORIES?= devel -MASTER_SITES= http://people.gnome.org/~veillard/gamin/sources/ - -MAINTAINER?= gnome@FreeBSD.org -COMMENT?= A file and directory monitoring system - -USE_AUTOTOOLS= libtool -USE_GMAKE= yes -USE_GETTEXT= yes -USE_GNOME?= gnomehack _glib20 -USE_PKGCONFIG= build -USE_LDCONFIG= yes -CONFIGURE_ARGS?=--with-html-dir=${PREFIX}/share/doc \ - --without-python -LDFLAGS+= -L${LOCALBASE}/lib ${PTHREAD_LIBS} -CPPFLAGS+= -DHAVE_LINUX -I${LOCALBASE}/include ${PTHREAD_CFLAGS} - -CONFLICTS= fam-[0-9]* - -GNU_CONFIGURE= yes - -.if !defined(GAMIN_SLAVE) -OPTIONS_DEFINE= GAM_POLLER LIBINOTIFY -GAM_POLLER_DESC=Use gamin's poller instead of kqueue's -LIBINOTIFY_DESC=Use libinotify as the FAM backend -.endif - -.include <bsd.port.pre.mk> - -.if !defined(GAM_SLAVE) -.if ${PORT_OPTIONS:MGAM_POLLER} -CPPFLAGS+= -DUSE_GAMIN_POLLER=1 -.endif - -.if ${PORT_OPTIONS:MLIBINOTIFY} -CONFIGURE_ARGS+=--enable-inotify -LDFLAGS+= -L${LOCALBASE}/lib -linotify -LIB_DEPENDS+= inotify:${PORTSDIR}/devel/libinotify -.else -CONFIGURE_ARGS+=--disable-inotify -.endif -.endif - -post-patch: - @${REINPLACE_CMD} "s|/etc|${PREFIX}/etc|g" ${WRKSRC}/server/gam_conf.c - -.if !defined(GAMIN_SLAVE) -regression-test: build - @${ECHO_MSG} "===> Running gamin regression tests" - @(cd ${WRKSRC}/tests && ${SETENV} ${MAKE_ENV} ${GMAKE} ${MAKE_FLAGS} \ - Makefile ${MAKE_ARGS} tests) - -post-install: - @${CAT} ${PKGMESSAGE} -.endif - -.include <bsd.port.post.mk> diff --git a/devel/gamin/distinfo b/devel/gamin/distinfo deleted file mode 100644 index 9e4e3874c..000000000 --- a/devel/gamin/distinfo +++ /dev/null @@ -1,2 +0,0 @@ -SHA256 (gamin-0.1.10.tar.gz) = 28085f0ae8be10eab582ff186af4fb0be92cc6c62b5cc19cd09b295c7c2899a1 -SIZE (gamin-0.1.10.tar.gz) = 653392 diff --git a/devel/gamin/files/patch-libgamin_gam_api.c b/devel/gamin/files/patch-libgamin_gam_api.c deleted file mode 100644 index 7c46e9335..000000000 --- a/devel/gamin/files/patch-libgamin_gam_api.c +++ /dev/null @@ -1,119 +0,0 @@ ---- libgamin/gam_api.c.orig Tue Feb 7 17:49:07 2006 -+++ libgamin/gam_api.c Tue Feb 7 17:49:13 2006 -@@ -14,6 +14,7 @@ - #include <sys/socket.h> - #include <sys/un.h> - #include <sys/uio.h> -+#include <string.h> - #include "fam.h" - #include "gam_protocol.h" - #include "gam_data.h" -@@ -421,10 +422,10 @@ - { - char data[2] = { 0, 0 }; - int written; --#if defined(HAVE_CMSGCRED) && !defined(LOCAL_CREDS) -- struct { -+#if defined(HAVE_CMSGCRED) && (!defined(LOCAL_CREDS) || defined(__FreeBSD__)) -+ union { - struct cmsghdr hdr; -- struct cmsgcred cred; -+ char cred[CMSG_SPACE (sizeof (struct cmsgcred))]; - } cmsg; - struct iovec iov; - struct msghdr msg; -@@ -436,16 +437,16 @@ - msg.msg_iov = &iov; - msg.msg_iovlen = 1; - -- msg.msg_control = &cmsg; -- msg.msg_controllen = sizeof (cmsg); -+ msg.msg_control = (caddr_t) &cmsg; -+ msg.msg_controllen = CMSG_SPACE (sizeof (struct cmsgcred)); - memset (&cmsg, 0, sizeof (cmsg)); -- cmsg.hdr.cmsg_len = sizeof (cmsg); -+ cmsg.hdr.cmsg_len = CMSG_LEN (sizeof (struct cmsgcred)); - cmsg.hdr.cmsg_level = SOL_SOCKET; - cmsg.hdr.cmsg_type = SCM_CREDS; - #endif - - retry: --#if defined(HAVE_CMSGCRED) && !defined(LOCAL_CREDS) -+#if defined(HAVE_CMSGCRED) && (!defined(LOCAL_CREDS) || defined(__FreeBSD__)) - written = sendmsg(fd, &msg, 0); - #else - written = write(fd, &data[0], 1); -@@ -647,15 +648,16 @@ - gid_t c_gid; - - #ifdef HAVE_CMSGCRED -- struct { -+ struct cmsgcred *cred; -+ union { - struct cmsghdr hdr; -- struct cmsgcred cred; -+ char cred[CMSG_SPACE (sizeof (struct cmsgcred))]; - } cmsg; - #endif - - s_uid = getuid(); - --#if defined(LOCAL_CREDS) && defined(HAVE_CMSGCRED) -+#if defined(LOCAL_CREDS) && defined(HAVE_CMSGCRED) && !defined(__FreeBSD__) - /* Set the socket to receive credentials on the next message */ - { - int on = 1; -@@ -676,8 +678,8 @@ - - #ifdef HAVE_CMSGCRED - memset(&cmsg, 0, sizeof(cmsg)); -- msg.msg_control = &cmsg; -- msg.msg_controllen = sizeof(cmsg); -+ msg.msg_control = (caddr_t) &cmsg; -+ msg.msg_controllen = CMSG_SPACE (sizeof (struct cmsgcred)); - #endif - - retry: -@@ -694,7 +696,7 @@ - goto failed; - } - #ifdef HAVE_CMSGCRED -- if (cmsg.hdr.cmsg_len < sizeof(cmsg) || cmsg.hdr.cmsg_type != SCM_CREDS) { -+ if (cmsg.hdr.cmsg_len < CMSG_LEN (sizeof (struct cmsgcred)) || cmsg.hdr.cmsg_type != SCM_CREDS) { - GAM_DEBUG(DEBUG_INFO, - "Message from recvmsg() was not SCM_CREDS\n"); - goto failed; -@@ -720,9 +722,10 @@ - goto failed; - } - #elif defined(HAVE_CMSGCRED) -- c_pid = cmsg.cred.cmcred_pid; -- c_uid = cmsg.cred.cmcred_euid; -- c_gid = cmsg.cred.cmcred_groups[0]; -+ cred = (struct cmsgcred *) CMSG_DATA (&cmsg); -+ c_pid = cred->cmcred_pid; -+ c_uid = cred->cmcred_euid; -+ c_gid = cred->cmcred_groups[0]; - #else /* !SO_PEERCRED && !HAVE_CMSGCRED */ - GAM_DEBUG(DEBUG_INFO, - "Socket credentials not supported on this OS\n"); -@@ -1283,14 +1286,17 @@ - - // FIXME: drop and reacquire lock while blocked? - gamin_data_lock(conn); -- if (!gamin_data_event_ready(conn)) { -+ while ((ret = gamin_data_event_ready(conn)) == 0) { - if (gamin_read_data(conn, fc->fd, 1) < 0) { - gamin_try_reconnect(conn, fc->fd); - FAMErrno = FAM_CONNECT; - return (-1); - } - } -- ret = gamin_data_read_event(conn, fe); -+ -+ if (ret > 0) -+ ret = gamin_data_read_event(conn, fe); -+ - gamin_data_unlock(conn); - - if (ret < 0) { diff --git a/devel/gamin/files/patch-python_Makefile.in b/devel/gamin/files/patch-python_Makefile.in deleted file mode 100644 index 24bbe73c6..000000000 --- a/devel/gamin/files/patch-python_Makefile.in +++ /dev/null @@ -1,20 +0,0 @@ ---- python/Makefile.in.orig 2008-11-26 01:42:29.000000000 -0500 -+++ python/Makefile.in 2008-11-26 01:43:26.000000000 -0500 -@@ -53,7 +53,7 @@ am__strip_dir = `echo $$p | sed -e 's|^. - am__installdirs = "$(DESTDIR)$(pythondir)" "$(DESTDIR)$(pythondir)" - pythonLTLIBRARIES_INSTALL = $(INSTALL) - LTLIBRARIES = $(python_LTLIBRARIES) --_gamin_la_DEPENDENCIES = $(top_builddir)/libgamin/libgamin-1.la -+_gamin_la_DEPENDENCIES = -lgamin-1 - am__gamin_la_OBJECTS = gamin.lo - _gamin_la_OBJECTS = $(am__gamin_la_OBJECTS) - _gamin_la_LINK = $(LIBTOOL) --tag=CC $(AM_LIBTOOLFLAGS) \ -@@ -228,7 +228,7 @@ INCLUDES = \ - - python_LTLIBRARIES = _gamin.la - _gamin_la_SOURCES = gamin.c --_gamin_la_LIBADD = $(top_builddir)/libgamin/libgamin-1.la -+_gamin_la_LIBADD = -lgamin-1 - _gamin_la_LDFLAGS = -module -avoid-version - python_PYTHON = gamin.py - all: all-recursive diff --git a/devel/gamin/files/patch-server__gam_node.h b/devel/gamin/files/patch-server__gam_node.h deleted file mode 100644 index 2490964c9..000000000 --- a/devel/gamin/files/patch-server__gam_node.h +++ /dev/null @@ -1,11 +0,0 @@ ---- server/gam_node.h.orig 2011-09-17 11:19:43.000000000 +0200 -+++ server/gam_node.h 2011-09-17 11:20:13.000000000 +0200 -@@ -58,7 +58,7 @@ gboolean gam_node_is_dir - void gam_node_set_is_dir (GamNode *node, - gboolean is_dir); - --G_CONST_RETURN char *gam_node_get_path (GamNode *node); -+const char *gam_node_get_path (GamNode *node); - - GList *gam_node_get_subscriptions (GamNode *node); - diff --git a/devel/gamin/files/patch-server__gam_subscription.c b/devel/gamin/files/patch-server__gam_subscription.c deleted file mode 100644 index 4c14baecb..000000000 --- a/devel/gamin/files/patch-server__gam_subscription.c +++ /dev/null @@ -1,11 +0,0 @@ ---- server/gam_subscription.c.orig 2011-09-17 11:17:22.000000000 +0200 -+++ server/gam_subscription.c 2011-09-17 11:17:44.000000000 +0200 -@@ -141,7 +141,7 @@ gam_subscription_pathlen(GamSubscription - * @param sub the GamSubscription - * @returns The path being monitored. It should not be freed. - */ --G_CONST_RETURN char * -+const char * - gam_subscription_get_path(GamSubscription * sub) - { - if (sub == NULL) diff --git a/devel/gamin/files/patch-server__gam_subscription.h b/devel/gamin/files/patch-server__gam_subscription.h deleted file mode 100644 index b8d5c3467..000000000 --- a/devel/gamin/files/patch-server__gam_subscription.h +++ /dev/null @@ -1,11 +0,0 @@ ---- server/gam_subscription.h.orig 2011-09-17 11:15:00.000000000 +0200 -+++ server/gam_subscription.h 2011-09-17 11:15:18.000000000 +0200 -@@ -21,7 +21,7 @@ int gam_subscription_pa - - int gam_subscription_get_reqno (GamSubscription *sub); - --G_CONST_RETURN char *gam_subscription_get_path (GamSubscription *sub); -+const char *gam_subscription_get_path (GamSubscription *sub); - - GamListener *gam_subscription_get_listener (GamSubscription *sub); - diff --git a/devel/gamin/files/patch-server_gam_channel.c b/devel/gamin/files/patch-server_gam_channel.c deleted file mode 100644 index 7b5fb8aee..000000000 --- a/devel/gamin/files/patch-server_gam_channel.c +++ /dev/null @@ -1,127 +0,0 @@ ---- server/gam_channel.c.orig Tue Aug 9 12:17:39 2005 -+++ server/gam_channel.c Fri Feb 10 01:22:46 2006 -@@ -7,6 +7,7 @@ - #include <sys/stat.h> - #include <sys/un.h> - #include <sys/uio.h> -+#include <string.h> - #include "gam_error.h" - #include "gam_connection.h" - #include "gam_channel.h" -@@ -30,10 +31,10 @@ gam_client_conn_send_cred(int fd) - { - char data[2] = { 0, 0 }; - int written; --#if defined(HAVE_CMSGCRED) && !defined(LOCAL_CREDS) -- struct { -+#if defined(HAVE_CMSGCRED) && (!defined(LOCAL_CREDS) || defined(__FreeBSD__)) -+ union { - struct cmsghdr hdr; -- struct cmsgcred cred; -+ char cred[CMSG_SPACE (sizeof (struct cmsgcred))]; - } cmsg; - struct iovec iov; - struct msghdr msg; -@@ -45,16 +46,16 @@ gam_client_conn_send_cred(int fd) - msg.msg_iov = &iov; - msg.msg_iovlen = 1; - -- msg.msg_control = &cmsg; -- msg.msg_controllen = sizeof (cmsg); -+ msg.msg_control = (caddr_t) &cmsg; -+ msg.msg_controllen = CMSG_SPACE (sizeof (struct cmsgcred)); - memset (&cmsg, 0, sizeof (cmsg)); -- cmsg.hdr.cmsg_len = sizeof (cmsg); -+ cmsg.hdr.cmsg_len = CMSG_LEN (sizeof (struct cmsgcred)); - cmsg.hdr.cmsg_level = SOL_SOCKET; - cmsg.hdr.cmsg_type = SCM_CREDS; - #endif - - retry: --#if defined(HAVE_CMSGCRED) && !defined(LOCAL_CREDS) -+#if defined(HAVE_CMSGCRED) && (!defined(LOCAL_CREDS) || defined(__FreeBSD__)) - written = sendmsg(fd, &msg, 0); - #else - written = write(fd, &data[0], 1); -@@ -95,15 +96,16 @@ gam_client_conn_check_cred(GIOChannel * - gid_t c_gid; - - #ifdef HAVE_CMSGCRED -- struct { -+ struct cmsgcred *cred; -+ union { - struct cmsghdr hdr; -- struct cmsgcred cred; -+ char cred[CMSG_SPACE (sizeof (struct cmsgcred))]; - } cmsg; - #endif - - s_uid = getuid(); - --#if defined(LOCAL_CREDS) && defined(HAVE_CMSGCRED) -+#if defined(LOCAL_CREDS) && defined(HAVE_CMSGCRED) && !defined(__FreeBSD__) - /* Set the socket to receive credentials on the next message */ - { - int on = 1; -@@ -124,8 +126,8 @@ gam_client_conn_check_cred(GIOChannel * - - #ifdef HAVE_CMSGCRED - memset(&cmsg, 0, sizeof(cmsg)); -- msg.msg_control = &cmsg; -- msg.msg_controllen = sizeof(cmsg); -+ msg.msg_control = (caddr_t) &cmsg; -+ msg.msg_controllen = CMSG_SPACE (sizeof (struct cmsgcred)); - #endif - - retry: -@@ -142,7 +144,7 @@ gam_client_conn_check_cred(GIOChannel * - goto failed; - } - #ifdef HAVE_CMSGCRED -- if (cmsg.hdr.cmsg_len < sizeof(cmsg) || cmsg.hdr.cmsg_type != SCM_CREDS) { -+ if (cmsg.hdr.cmsg_len < CMSG_LEN (sizeof (struct cmsgcred)) || cmsg.hdr.cmsg_type != SCM_CREDS) { - GAM_DEBUG(DEBUG_INFO, - "Message from recvmsg() was not SCM_CREDS\n"); - goto failed; -@@ -168,9 +170,10 @@ gam_client_conn_check_cred(GIOChannel * - goto failed; - } - #elif defined(HAVE_CMSGCRED) -- c_pid = cmsg.cred.cmcred_pid; -- c_uid = cmsg.cred.cmcred_euid; -- c_gid = cmsg.cred.cmcred_groups[0]; -+ cred = (struct cmsgcred *) CMSG_DATA (&cmsg); -+ c_pid = cred->cmcred_pid; -+ c_uid = cred->cmcred_euid; -+ c_gid = cred->cmcred_groups[0]; - #else /* !SO_PEERCRED && !HAVE_CMSGCRED */ - GAM_DEBUG(DEBUG_INFO, - "Socket credentials not supported on this OS\n"); -@@ -620,6 +621,7 @@ gam_listen_unix_socket(const char *path) - { - int fd; - struct sockaddr_un addr; -+ struct stat st; - - fd = socket(PF_UNIX, SOCK_STREAM, 0); - if (fd < 0) { -@@ -640,8 +642,18 @@ gam_listen_unix_socket(const char *path) - * some extra protection checks. Also make sure the socket is created - * with restricted mode - */ -- if (!gam_check_secure_path(path)) { -+ if (!gam_check_secure_dir()) { -+ close(fd); - return (-1); -+ } -+ -+ if (stat(path, &st) == 0) { -+ /* bind() will fail if the socket already exists */ -+ if (unlink(path) < 0) { -+ GAM_DEBUG(DEBUG_INFO, "Failed to remove %s\n", path); -+ close(fd); -+ return (-1); -+ } - } - strncpy(&addr.sun_path[0], path, (sizeof(addr) - 4) - 1); - umask(0077); diff --git a/devel/gamin/files/patch-server_gam_eq.c b/devel/gamin/files/patch-server_gam_eq.c deleted file mode 100644 index 6dfb7c975..000000000 --- a/devel/gamin/files/patch-server_gam_eq.c +++ /dev/null @@ -1,11 +0,0 @@ ---- server/gam_eq.c.orig 2012-05-13 19:42:20.257794534 +0400 -+++ server/gam_eq.c 2012-05-13 19:44:41.228799909 +0400 -@@ -124,7 +124,7 @@ gam_eq_flush (gam_eq_t *eq, GamConnDataP - { - gboolean done_work = FALSE; - if (!eq) -- return; -+ return FALSE; - - #ifdef GAM_EQ_VERBOSE - GAM_DEBUG(DEBUG_INFO, "gam_eq: Flushing event queue for %s\n", gam_connection_get_pidname (conn)); diff --git a/devel/gamin/files/patch-server_gam_fs.c b/devel/gamin/files/patch-server_gam_fs.c deleted file mode 100644 index 2fcc24209..000000000 --- a/devel/gamin/files/patch-server_gam_fs.c +++ /dev/null @@ -1,161 +0,0 @@ ---- server/gam_fs.c.orig 2007-07-04 09:36:49.000000000 -0400 -+++ server/gam_fs.c 2007-08-10 15:05:41.000000000 -0400 -@@ -7,6 +7,11 @@ - #include <string.h> - #include <errno.h> - #include <glib.h> -+#ifdef __FreeBSD__ -+#include <sys/param.h> -+#include <sys/ucred.h> -+#include <sys/mount.h> -+#endif - #include "gam_error.h" - #include "gam_fs.h" - -@@ -21,9 +26,13 @@ typedef struct _gam_fs_properties { - typedef struct _gam_fs { - char *path; - char *fsname; -+ guint64 flags; - } gam_fs; - - static gboolean initialized = FALSE; -+#ifdef __FreeBSD__ -+static gboolean initializing = FALSE; -+#endif - static GList *filesystems = NULL; - static GList *fs_props = NULL; - static struct stat mtab_sbuf; -@@ -110,6 +119,7 @@ gam_fs_filesystem_sort_cb (gconstpointer - return strlen(fsb->path) - strlen (fsa->path); - } - -+#ifdef __linux__ - static void - gam_fs_scan_mtab (void) - { -@@ -165,10 +175,41 @@ gam_fs_scan_mtab (void) - gam_fs_free_filesystems (); - filesystems = g_list_sort (new_filesystems, gam_fs_filesystem_sort_cb); - } -+#endif -+ -+#ifdef __FreeBSD__ -+static void -+gam_fs_getmntinfo (void) -+{ -+ struct statfs *stat; -+ GList *new_filesystems = NULL; -+ gam_fs *fs = NULL; -+ int i, n; -+ -+ n = getmntinfo(&stat, MNT_NOWAIT); -+ if (n == -1) -+ return; -+ -+ for (i = 0; i < n; i++) -+ { -+ fs = g_new0 (gam_fs, 1); -+ fs->path = g_strdup (stat[i].f_mntonname); -+ fs->fsname = g_strdup (stat[i].f_fstypename); -+ fs->flags = stat[i].f_flags; -+ -+ new_filesystems = g_list_prepend (new_filesystems, fs); -+ } -+ -+ /* Replace the old file systems list with the new one */ -+ gam_fs_free_filesystems (); -+ filesystems = g_list_sort (new_filesystems, gam_fs_filesystem_sort_cb); -+} -+#endif - - void - gam_fs_init (void) - { -+#if defined(__linux__) - if (initialized == FALSE) - { - initialized = TRUE; -@@ -181,6 +222,7 @@ gam_fs_init (void) - if (stat("/etc/mtab", &mtab_sbuf) != 0) - { - GAM_DEBUG(DEBUG_INFO, "Could not stat /etc/mtab\n"); -+ return; - } - gam_fs_scan_mtab (); - } else { -@@ -189,6 +231,7 @@ gam_fs_init (void) - if (stat("/etc/mtab", &sbuf) != 0) - { - GAM_DEBUG(DEBUG_INFO, "Could not stat /etc/mtab\n"); -+ return; - } - - /* /etc/mtab has changed */ -@@ -199,6 +242,54 @@ gam_fs_init (void) - - mtab_sbuf = sbuf; - } -+#elif defined(__FreeBSD__) -+ if (initialized == FALSE && initializing == FALSE) -+ { -+ GList *iterator = NULL; -+ GHashTable *fs_hash = NULL; -+ gam_fs *fs = NULL; -+ -+ initialized = TRUE; -+ initializing = TRUE; -+ -+ gam_fs_getmntinfo (); -+ -+ iterator = filesystems; -+ fs_hash = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, NULL); -+ -+ while (iterator) { -+ fs = iterator->data; -+ -+ if (!g_hash_table_lookup (fs_hash, fs->fsname)) { -+ if (fs->flags & MNT_LOCAL) -+ gam_fs_set (fs->fsname, GFS_MT_DEFAULT, 0); -+ else -+ gam_fs_set (fs->fsname, GFS_MT_POLL, 5); -+ -+ g_hash_table_insert (fs_hash, g_strdup (fs->fsname), GINT_TO_POINTER (1)); -+ } -+ -+ iterator = g_list_next (iterator); -+ } -+ -+ g_hash_table_destroy (fs_hash); -+ initializing = FALSE; -+ } else if (initializing == FALSE) { -+ struct stat sbuf; -+ -+ if (stat ("/etc/fstab", &sbuf) != 0) { -+ GAM_DEBUG(DEBUG_INFO, "Could not stat /etc/fstab\n"); -+ return; -+ } -+ -+ if (sbuf.st_mtime != mtab_sbuf.st_mtime) { -+ GAM_DEBUG(DEBUG_INFO, "Updating list of mounted filesystems\n"); -+ gam_fs_getmntinfo (); -+ } -+ -+ mtab_sbuf = sbuf; -+ } -+#endif - } - - gam_fs_mon_type -@@ -210,7 +301,11 @@ gam_fs_get_mon_type (const char *path) - props = gam_fs_find_fs_props (path); - - if (!props) -+#ifdef USE_GAMIN_POLLER -+ return GFS_MT_POLL; -+#else - return GFS_MT_DEFAULT; -+#endif - - return props->mon_type; - } diff --git a/devel/gamin/files/patch-server_gam_kqueue.c b/devel/gamin/files/patch-server_gam_kqueue.c deleted file mode 100644 index 89289c533..000000000 --- a/devel/gamin/files/patch-server_gam_kqueue.c +++ /dev/null @@ -1,356 +0,0 @@ ---- server/gam_kqueue.c.orig 2007-07-04 09:50:41.000000000 -0400 -+++ server/gam_kqueue.c 2009-06-03 13:43:38.000000000 -0400 -@@ -5,7 +5,8 @@ - * - * * http://techpubs.sgi.com/library/tpl/cgi-bin/getdoc.cgi?coll=0650&db=bks&fname=/SGI_Developer/books/IIDsktp_IG/sgi_html/ch08.html - * states that FAM does not follow monitored symbolic links: we -- * do the same (note that regarding -+ * do NOT do the same to preserve compatibility with SGI FAM (note -+ * that regarding - * http://oss.sgi.com/bugzilla/show_bug.cgi?id=405, we do what - * FAM should do: we do not call g_dir_open() if the file is a - * symbolic link). -@@ -28,10 +29,9 @@ - * - kqueue needs to be augmented with a filename-based - * monitoring facility; - * -- * - kqueue needs to be moved out the UFS code. -- * - * Copyright (C) 2005 Joe Marcus Clarke <marcus@FreeBSD.org> -- * Copyright (C) 2005 Jean-Yves Lefort <jylefort@FreeBSD.org> -+ * Copyright (C) 2005, 2006 Jean-Yves Lefort <jylefort@FreeBSD.org> -+ * Copyright (C) 2006 Alex Dupre <ale@FreeBSD.org> - * - * This library is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public -@@ -53,6 +53,9 @@ - #include <fcntl.h> - #include <unistd.h> - #include <sys/param.h> -+#ifndef USE_GAMIN_POLLER -+#include <sys/mount.h> -+#endif - #include <sys/types.h> - #include <sys/sysctl.h> - #include <sys/stat.h> -@@ -62,6 +65,7 @@ - #include "gam_error.h" - #include "gam_kqueue.h" - #include "gam_event.h" -+#include "gam_excludes.h" - #include "gam_server.h" - #include "gam_poll_basic.h" - -@@ -130,7 +134,7 @@ typedef struct - HashTableRemoveFunc remove; - HashTablePostRemoveFunc post_remove; - } HashTableMethods; -- -+ - /* - * A hash table which can be modified while iterating over it. - */ -@@ -281,8 +285,8 @@ static void - gam_kqueue_mini_lstat (const char *pathname, MiniStat *mini_sb) - { - struct stat sb; -- -- if (lstat(pathname, &sb) < 0) -+ -+ if (stat(pathname, &sb) < 0) - memset(mini_sb, 0, sizeof(*mini_sb)); - else - { -@@ -319,14 +323,14 @@ gam_kqueue_isdir (const char *pathname, - else - { - struct stat sb; -- return lstat(pathname, &sb) >= 0 && (sb.st_mode & S_IFDIR) != 0; -+ return stat(pathname, &sb) >= 0 && (sb.st_mode & S_IFDIR) != 0; - } - } - - static gboolean - gam_kqueue_get_uint_sysctl (const char *name, unsigned int *value) - { -- unsigned int value_len = sizeof(*value); -+ size_t value_len = sizeof(*value); - - if (sysctlbyname(name, value, &value_len, (void *)NULL, 0) < 0) - { -@@ -406,7 +410,7 @@ gam_kqueue_hash_table_foreach (HashTable - table->iterating = TRUE; - g_hash_table_foreach(table->main, func, user_data); - table->iterating = FALSE; -- -+ - if (table->pending_additions) - { - GSList *l; -@@ -509,33 +513,52 @@ static gboolean - gam_kqueue_monitor_enable_kqueue (Monitor *mon) - { - struct kevent ev[1]; -+#ifndef USE_GAMIN_POLLER -+ struct statfs sb; -+#endif - - if (open_files == max_open_files) - { - GAM_DEBUG(DEBUG_INFO, "cannot open %s (max_open_files limit reached), falling back to poll\n", mon->pathname); - return FALSE; - } -- -- mon->fd = open(mon->pathname, O_RDONLY | O_NOFOLLOW); -+ -+ if (gam_exclude_check(mon->pathname)) -+ { -+ GAM_DEBUG(DEBUG_INFO, "not using kqueue for %s since it is excluded, falling back to poll\n", mon->pathname); -+ return FALSE; -+ } -+ -+ mon->fd = open(mon->pathname, O_RDONLY | O_NONBLOCK | O_NOFOLLOW); - if (mon->fd < 0) - { - GAM_DEBUG(DEBUG_INFO, "cannot open %s (%s), falling back to poll\n", mon->pathname, g_strerror(errno)); - return FALSE; - } - -+#ifndef USE_GAMIN_POLLER -+ if (fstatfs(mon->fd, &sb) == 0 && (sb.f_flags & MNT_LOCAL) == 0) -+ { -+ GAM_DEBUG(DEBUG_INFO, "%s resides on a remote file system, falling back to poll\n", mon->pathname); -+ goto poll; -+ } -+#endif -+ - EV_SET(ev, mon->fd, EVFILT_VNODE, EV_ADD | EV_ENABLE | EV_CLEAR, VN_NOTE_ALL, 0, mon); - if (kevent(kq, ev, G_N_ELEMENTS(ev), NULL, 0, NULL) < 0) - { - GAM_DEBUG(DEBUG_INFO, "cannot enable kqueue notification for %s (%s), falling back to poll\n", mon->pathname, g_strerror(errno)); -- -- close(mon->fd); -- mon->fd = -1; -- -- return FALSE; -+ goto poll; - } - - open_files++; - return TRUE; -+ -+ poll: -+ close(mon->fd); -+ mon->fd = -1; -+ -+ return FALSE; - } - - static void -@@ -612,7 +635,7 @@ gam_kqueue_sub_monitor_free (SubMonitor - gam_kqueue_poller_remove_sub_monitor(&missing_smon_poller, smon); - gam_kqueue_poller_remove_sub_monitor(&unsupported_smon_poller, smon); - /* unsupported_dirs_poller is handled by _clear_fmons() below */ -- -+ - gam_kqueue_sub_monitor_clear_fmons(smon); - gam_kqueue_monitor_free(MONITOR(smon)); - } -@@ -700,7 +723,7 @@ gam_kqueue_sub_monitor_enable_notificati - { - struct stat sb; - -- exists = lstat(mon->pathname, &sb) >= 0; -+ exists = stat(mon->pathname, &sb) >= 0; - flags |= (exists && (sb.st_mode & S_IFDIR) != 0) ? MONITOR_ISDIR : MONITOR_ISNOTDIR; - } - -@@ -715,21 +738,21 @@ gam_kqueue_sub_monitor_enable_notificati - { - GDir *dir; - GError *err = NULL; -- -+ - dir = g_dir_open(mon->pathname, 0, &err); - if (dir) - { - const char *filename; -- -+ - while ((filename = g_dir_read_name(dir))) - { - FileMonitor *fmon; - FileMonitorFlags fmon_flags; -- -+ - fmon = gam_kqueue_file_monitor_new(smon, filename, &fmon_flags); - gam_kqueue_file_monitor_emit_event(fmon, gevent, fmon_flags); - } -- -+ - g_dir_close(dir); - } - else -@@ -749,7 +772,7 @@ gam_kqueue_sub_monitor_enable_notificati - - return; - } -- -+ - /* then we enable kqueue notification, falling back to poll if necessary */ - - if (! gam_kqueue_monitor_enable_kqueue(mon)) -@@ -774,7 +797,7 @@ gam_kqueue_sub_monitor_handle_directory_ - - filenames = g_hash_table_new_full(g_str_hash, g_str_equal, g_free, NULL); - -- if (isdir) /* do not follow symbolic links */ -+ if (isdir) - { - GDir *dir; - GError *err = NULL; -@@ -783,7 +806,7 @@ gam_kqueue_sub_monitor_handle_directory_ - if (dir) - { - const char *filename; -- -+ - while ((filename = g_dir_read_name(dir))) - { - g_hash_table_insert(filenames, g_strdup(filename), GINT_TO_POINTER(TRUE)); -@@ -793,12 +816,12 @@ gam_kqueue_sub_monitor_handle_directory_ - { - FileMonitor *fmon; - FileMonitorFlags fmon_flags; -- -+ - fmon = gam_kqueue_file_monitor_new(smon, filename, &fmon_flags); - gam_kqueue_file_monitor_emit_event(fmon, GAMIN_EVENT_CREATED, fmon_flags); - } - } -- -+ - g_dir_close(dir); - } - else -@@ -840,6 +863,8 @@ gam_kqueue_sub_monitor_emit_event (SubMo - case GAMIN_EVENT_MOVED: - gam_kqueue_sub_monitor_set_missing(smon); - break; -+ default: -+ break; - } - - gam_server_emit_event(mon->pathname, isdir, event, smon->subs, 1); -@@ -931,11 +956,11 @@ gam_kqueue_file_monitor_emit_event (File - gboolean isdir; - gboolean stat_done; - gboolean stat_succeeded; -- -+ - if ((flags & MONITOR_ISDIR) == 0 && (flags & MONITOR_ISNOTDIR) == 0) - { - stat_done = TRUE; -- stat_succeeded = lstat(mon->pathname, &sb) >= 0; -+ stat_succeeded = stat(mon->pathname, &sb) >= 0; - isdir = stat_succeeded && (sb.st_mode & S_IFDIR) != 0; - } - else -@@ -943,7 +968,7 @@ gam_kqueue_file_monitor_emit_event (File - stat_done = FALSE; - isdir = (flags & MONITOR_ISDIR) != 0; - } -- -+ - gam_server_emit_event(mon->pathname, isdir, event, fmon->smon->subs, 1); - - switch (event) -@@ -962,7 +987,7 @@ gam_kqueue_file_monitor_emit_event (File - { - FileMonitor *new_fmon; - FileMonitorFlags new_fmon_flags; -- -+ - /* - * The file exists again. It means that kqueue has - * aggregated a removal+creation into a single event. We -@@ -978,9 +1003,11 @@ gam_kqueue_file_monitor_emit_event (File - break; /* do not remove the fmon we've just created */ - } - } -- -+ - gam_kqueue_hash_table_remove(fmon->smon->fmons, fmon); - break; -+ default: -+ break; - } - } - -@@ -1033,7 +1060,7 @@ gam_kqueue_kevent_cb (GIOChannel *source - - for (i = 0; i < nevents; i++) - MONITOR(ev[i].udata)->handle_kevent(MONITOR(ev[i].udata), &ev[i]); -- -+ - return TRUE; /* keep source */ - } - -@@ -1042,7 +1069,7 @@ gam_kqueue_missing_smon_poll (SubMonitor - { - struct stat sb; - -- if (lstat(MONITOR(smon)->pathname, &sb) >= 0) -+ if (stat(MONITOR(smon)->pathname, &sb) >= 0) - { - gam_kqueue_poller_remove_sub_monitor(&missing_smon_poller, smon); - gam_kqueue_sub_monitor_enable_notification(smon, SUB_MONITOR_WAS_MISSING | ((sb.st_mode & S_IFDIR) != 0 ? MONITOR_ISDIR : MONITOR_ISNOTDIR)); -@@ -1062,16 +1089,16 @@ gam_kqueue_unsupported_smon_poll (SubMon - if (gam_kqueue_monitor_enable_kqueue(mon)) - gam_kqueue_poller_remove_sub_monitor(&missing_smon_poller, smon); - } -- -+ - gam_kqueue_mini_lstat(mon->pathname, &sb); -- -+ - if (! sb.exists && mon->sb.exists) - event = GAMIN_EVENT_DELETED; - else if (gam_kqueue_differs(&sb, &mon->sb)) - event = GAMIN_EVENT_CHANGED; - else - return; -- -+ - memcpy(&mon->sb, &sb, sizeof(sb)); - gam_kqueue_sub_monitor_emit_event(smon, event, (sb.mode & S_IFDIR) != 0 ? MONITOR_ISDIR : MONITOR_ISNOTDIR); - } -@@ -1167,7 +1194,10 @@ gam_kqueue_init (void) - channel = g_io_channel_unix_new(kq); - g_io_add_watch(channel, G_IO_IN, gam_kqueue_kevent_cb, NULL); - -- -+#ifdef USE_GAMIN_POLLER -+ gam_poll_basic_init (); -+#endif -+ - gam_server_install_kernel_hooks(GAMIN_K_KQUEUE, - gam_kqueue_add_subscription, - gam_kqueue_remove_subscription, -@@ -1200,7 +1230,7 @@ gam_kqueue_add_subscription (GamSubscrip - smon->subs = g_list_append(smon->subs, sub); - return TRUE; - } -- -+ - smon = gam_kqueue_sub_monitor_new(sub); - smon->subs = g_list_append(smon->subs, sub); - -@@ -1260,6 +1290,6 @@ gam_kqueue_remove_all_for (GamListener * - success = FALSE; - - g_list_free(subs); -- -+ - return success; - } diff --git a/devel/gamin/files/patch-server_gam_node.c b/devel/gamin/files/patch-server_gam_node.c deleted file mode 100644 index 4330949d0..000000000 --- a/devel/gamin/files/patch-server_gam_node.c +++ /dev/null @@ -1,19 +0,0 @@ ---- server/gam_node.c.orig 2007-07-04 15:36:49.000000000 +0200 -+++ server/gam_node.c 2011-09-17 11:19:10.000000000 +0200 -@@ -23,6 +23,7 @@ - #include "gam_event.h" - #include "gam_node.h" - #include "gam_error.h" -+#include "gam_server.h" - - /** - * Create a new node -@@ -122,7 +123,7 @@ gam_node_set_is_dir(GamNode * node, gboo - * it has finished with the string. If it must keep it longer, it - * should makes its own copy. The returned string must not be freed. - */ --G_CONST_RETURN char * -+const char * - gam_node_get_path(GamNode * node) - { - g_assert(node); diff --git a/devel/gamin/files/patch-server_gam_poll_basic.c b/devel/gamin/files/patch-server_gam_poll_basic.c deleted file mode 100644 index 9a0333149..000000000 --- a/devel/gamin/files/patch-server_gam_poll_basic.c +++ /dev/null @@ -1,11 +0,0 @@ ---- server/gam_poll_basic.c.orig 2007-08-10 15:12:29.000000000 -0400 -+++ server/gam_poll_basic.c 2007-08-10 15:16:07.000000000 -0400 -@@ -345,7 +345,7 @@ gam_poll_basic_poll_file(GamNode * node) - #ifdef ST_MTIM_NSEC - GAM_DEBUG(DEBUG_INFO, "%d %d : %d %d\n", node->sbuf.st_mtim.tv_sec, node->sbuf.st_mtim.tv_nsec, sbuf.st_mtim.tv_sec, sbuf.st_mtim.tv_nsec); - #else -- GAM_DEBUG(DEBUG_INFO, "%d : %d\n", node->sbuf.st_mtime, sbuf.st_mtim.tv_nsec); -+ GAM_DEBUG(DEBUG_INFO, "%d : %d\n", node->sbuf.st_mtime, sbuf.st_mtime); - #endif /* ST_MTIM_NSEC */ - #endif /* VERBOSE_POLL */ - } diff --git a/devel/gamin/files/patch-server_gam_server.c b/devel/gamin/files/patch-server_gam_server.c deleted file mode 100644 index 77c9b75f4..000000000 --- a/devel/gamin/files/patch-server_gam_server.c +++ /dev/null @@ -1,40 +0,0 @@ ---- server/gam_server.c.orig 2007-07-04 09:36:49.000000000 -0400 -+++ server/gam_server.c 2009-05-01 20:25:41.000000000 -0400 -@@ -32,7 +32,7 @@ - #include "gam_server.h" - #include "gam_channel.h" - #include "gam_subscription.h" --#include "gam_poll_generic.h" -+#include "gam_poll_basic.h" - #ifdef ENABLE_INOTIFY - #include "gam_inotify.h" - #endif -@@ -200,7 +200,8 @@ gam_add_subscription(GamSubscription * s - return gam_poll_add_subscription (sub); - else - #endif -- return gam_kernel_add_subscription (sub); -+ /*return gam_kernel_add_subscription (sub);*/ -+ return gam_poll_add_subscription (sub); - } else { - gam_fs_mon_type type; - type = gam_fs_get_mon_type (path); -@@ -243,7 +244,8 @@ gam_remove_subscription(GamSubscription - return gam_poll_remove_subscription (sub); - else - #endif -- return gam_kernel_remove_subscription(sub); -+ /*return gam_kernel_remove_subscription(sub);*/ -+ return gam_poll_remove_subscription (sub); - } else { - gam_fs_mon_type type; - type = gam_fs_get_mon_type (path); -@@ -438,7 +440,7 @@ gam_server_get_kernel_handler (void) - GamPollHandler - gam_server_get_poll_handler (void) - { -- return __gam_kernel_handler; -+ return __gam_poll_handler; - } - - gboolean diff --git a/devel/gamin/files/patch-tests_testing.c b/devel/gamin/files/patch-tests_testing.c deleted file mode 100644 index 35097790d..000000000 --- a/devel/gamin/files/patch-tests_testing.c +++ /dev/null @@ -1,27 +0,0 @@ ---- tests/testing.c.orig Thu Oct 27 10:51:03 2005 -+++ tests/testing.c Tue Feb 14 17:46:01 2006 -@@ -376,11 +376,11 @@ processCommand(char *line, int no) - } - printf("chmod %s to %s\n", arg, arg2); - } else if (!strcmp(command, "chown")) { -+ struct stat sb; - if (args != 3) { - fprintf(stderr, "chown line %d: lacks path and owner\n", no); - return (-1); - } -- struct stat sb; - if (!lstat (arg, &sb)) { - ret = (S_ISLNK (sb.st_mode)) ? - lchown(arg, strtol(arg2, NULL, 10), -1) : -@@ -486,9 +486,9 @@ processCommand(char *line, int no) - return (-1); - } - /* -- * wait at most 3 secs before declaring failure -+ * wait at most 7 secs before declaring failure - */ -- while ((delay < 30) && (testState.nb_events < nb_events + count)) { -+ while ((delay < 70) && (testState.nb_events < nb_events + count)) { - debugLoop(100); - - /* printf("+"); fflush(stdout); */ diff --git a/devel/gamin/pkg-descr b/devel/gamin/pkg-descr deleted file mode 100644 index 7bac17f94..000000000 --- a/devel/gamin/pkg-descr +++ /dev/null @@ -1,8 +0,0 @@ -Gamin is a file and directory monitoring system defined to be a subset of the -FAM (File Alteration Monitor) system. This is a service provided by a library -which allows to detect when a file or a directory has been modified. - -Whereas the FreeBSD port of FAM polls files every few seconds, this port -includes a kqueue(2) backend for immediate notification of most alterations. - -WWW: http://www.gnome.org/~veillard/gamin/index.html diff --git a/devel/gamin/pkg-message b/devel/gamin/pkg-message deleted file mode 100644 index 28586c6c6..000000000 --- a/devel/gamin/pkg-message +++ /dev/null @@ -1,26 +0,0 @@ -=============================================================================== - -Gamin will only provide realtime notification of changes for at most n files, -where n is the minimum value between (kern.maxfiles * 0.7) and -(kern.maxfilesperproc - 200). Beyond that limit, files will be polled. - -If you often open several large folders with Nautilus, you might want to -increase the kern.maxfiles tunable (you do not need to set -kern.maxfilesperproc, since it is computed at boot time from kern.maxfiles). - -For a typical desktop, add the following line to /boot/loader.conf, then -reboot the system: - - kern.maxfiles="25000" - -The behavior of gamin can be controlled via the various gaminrc files. -See http://www.gnome.org/~veillard/gamin/config.html on how to create -these files. In particular, if you find gam_server is taking up too much -CPU time polling for changes, something like the following may help -in one of the gaminrc files: - -# reduce polling frequency to once per 10 seconds -# for UFS file systems in order to lower CPU load -fsset ufs poll 10 - -=============================================================================== diff --git a/devel/gamin/pkg-plist b/devel/gamin/pkg-plist deleted file mode 100644 index 008f29b34..000000000 --- a/devel/gamin/pkg-plist +++ /dev/null @@ -1,12 +0,0 @@ -include/fam.h -lib/libfam.a -lib/libfam.la -lib/libfam.so -lib/libfam.so.0 -lib/libgamin-1.a -lib/libgamin-1.la -lib/libgamin-1.so -lib/libgamin-1.so.1 -lib/libgamin_shared.a -libdata/pkgconfig/gamin.pc -libexec/gam_server |