summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMartin Schlemmer <azarah@gentoo.org>2005-08-20 16:05:30 +0000
committerMartin Schlemmer <azarah@gentoo.org>2005-08-20 16:05:30 +0000
commit3521cc618bc6f48d2e638e4f0fa459611a8aa157 (patch)
tree80605ac3465af12b6982804a6244a81c10e14e13 /app-admin
parentUpdate version. (diff)
downloadhistorical-3521cc618bc6f48d2e638e4f0fa459611a8aa157.tar.gz
historical-3521cc618bc6f48d2e638e4f0fa459611a8aa157.tar.bz2
historical-3521cc618bc6f48d2e638e4f0fa459611a8aa157.zip
Remove old versions.
Package-Manager: portage-2.0.51.22-r2
Diffstat (limited to 'app-admin')
-rw-r--r--app-admin/gamin/Manifest13
-rw-r--r--app-admin/gamin/files/digest-gamin-0.1.11
-rw-r--r--app-admin/gamin/files/digest-gamin-0.1.21
-rw-r--r--app-admin/gamin/files/gamin-0.1.1-inotify-fix.patch482
-rw-r--r--app-admin/gamin/files/gamin-0.1.2-freebsd.patch124
-rw-r--r--app-admin/gamin/files/gamin-0.1.2-inotify-legacy-backend.patch884
-rw-r--r--app-admin/gamin/gamin-0.1.1.ebuild55
-rw-r--r--app-admin/gamin/gamin-0.1.2.ebuild70
8 files changed, 3 insertions, 1627 deletions
diff --git a/app-admin/gamin/Manifest b/app-admin/gamin/Manifest
index fb0d1aa9c6af..b3392dc284f8 100644
--- a/app-admin/gamin/Manifest
+++ b/app-admin/gamin/Manifest
@@ -2,25 +2,18 @@
Hash: SHA1
MD5 ae02647e4752424ec1c60c3f6925c9ed gamin-0.1.3.ebuild 1830
-MD5 4dcf9ef178820168a4233e6f8fbbd6ee gamin-0.1.2.ebuild 1812
MD5 994b2591ca8e1301ce52043306c94713 ChangeLog 5548
-MD5 03f3bc849895689c9635a6a7e8c11d0b gamin-0.1.1.ebuild 1345
MD5 875135e8740bafa4dab79ee592cf9744 metadata.xml 279
MD5 bec8a6310f144fd3c15b9cd0a8699bbd gamin-0.1.5.ebuild 1829
-MD5 fd8dba98fd1b79aed73e3b6f17e0a779 files/digest-gamin-0.1.1 63
MD5 84f3255901e8fa0574b40df22ee54cea files/gamin-0.1.5-inotify-legacy-backend.patch 27609
-MD5 50691da4c01bbd32e1397b8873180986 files/gamin-0.1.1-inotify-fix.patch 14533
MD5 65e3ff0dfeabee2182ee256c943f5b37 files/digest-gamin-0.1.3 63
MD5 20a4a3c7c4794dfac0d00d75ef58fb96 files/digest-gamin-0.1.5 63
MD5 510d70d44de83d7822311077a39621c8 files/gamin-0.1.3-freebsd.patch 3857
-MD5 6e519de04a1b260384534977bb6ba1f6 files/gamin-0.1.2-freebsd.patch 4550
MD5 281a6a262337245c21884f5afdd616b3 files/gamin-0.1.3-inotify-legacy-backend.patch 27609
-MD5 2ab0167c306465e140ebfe2d8151fced files/digest-gamin-0.1.2 63
-MD5 67e42fe9ea88f0a3a0bc59377d43aab5 files/gamin-0.1.2-inotify-legacy-backend.patch 27593
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.2 (GNU/Linux)
-iD8DBQFDB1RQ1ZcsMnZjRyIRAmLCAKCg1rraaAEOK/7r/hGW8NW2juVEDwCeKN29
-DRFJoa3wxyclD0tzW+vWT8g=
-=iGJv
+iD8DBQFDB1VD1ZcsMnZjRyIRAvBEAJ9xz6N6MQp2iW3NVsSItMENjPz5BQCeNTZN
+iVP7786UCKVnD49XvJXiddM=
+=mBlh
-----END PGP SIGNATURE-----
diff --git a/app-admin/gamin/files/digest-gamin-0.1.1 b/app-admin/gamin/files/digest-gamin-0.1.1
deleted file mode 100644
index f33e19ddded8..000000000000
--- a/app-admin/gamin/files/digest-gamin-0.1.1
+++ /dev/null
@@ -1 +0,0 @@
-MD5 5c5330c3df26ece7d71b69a0b8f4a126 gamin-0.1.1.tar.gz 512316
diff --git a/app-admin/gamin/files/digest-gamin-0.1.2 b/app-admin/gamin/files/digest-gamin-0.1.2
deleted file mode 100644
index a079a2f4c1a1..000000000000
--- a/app-admin/gamin/files/digest-gamin-0.1.2
+++ /dev/null
@@ -1 +0,0 @@
-MD5 cb43e73d43e2c5d428229dea0288d66d gamin-0.1.2.tar.gz 513784
diff --git a/app-admin/gamin/files/gamin-0.1.1-inotify-fix.patch b/app-admin/gamin/files/gamin-0.1.1-inotify-fix.patch
deleted file mode 100644
index 5dbb9e415516..000000000000
--- a/app-admin/gamin/files/gamin-0.1.1-inotify-fix.patch
+++ /dev/null
@@ -1,482 +0,0 @@
-===================================================================
-RCS file: /cvs/gnome/gamin/server gam_dnotify.c,v
-retrieving revision 1.19
-retrieving revision 1.20
-diff -u -r1.19 -r1.20
---- server/gam_dnotify.c 2005/06/08 13:57:28 1.19
-+++ server/gam_dnotify.c 2005/06/13 09:13:45 1.20
-@@ -58,6 +58,29 @@
-
- static gboolean have_consume_idler = FALSE;
-
-+void
-+gam_dnotify_data_debug (gpointer key, gpointer value, gpointer user_data)
-+{
-+ DNotifyData *data = (DNotifyData *)value;
-+
-+ if (!data)
-+ return;
-+
-+ int deactivated = data->fd == -1 ? 1 : 0;
-+
-+ GAM_DEBUG(DEBUG_INFO, "dsub fd %d refs %d busy %d deactivated %d: %s\n", data->fd, data->refcount, data->busy, deactivated, data->path);
-+}
-+
-+void
-+gam_dnotify_debug (void)
-+{
-+ if (path_hash == NULL)
-+ return;
-+
-+ GAM_DEBUG(DEBUG_INFO, "Dumping dnotify subscriptions\n");
-+ g_hash_table_foreach (path_hash, gam_dnotify_data_debug, NULL);
-+}
-+
- static DNotifyData *
- gam_dnotify_data_new(const char *path, int fd)
- {
-===================================================================
-RCS file: /cvs/gnome/gamin/server gam_dnotify.h,v
-retrieving revision 1.1
-retrieving revision 1.2
-diff -u -r1.1 -r1.2
---- server/gam_dnotify.h 2004/06/15 19:30:49 1.1
-+++ server/gam_dnotify.h 2005/06/13 09:13:45 1.2
-@@ -12,6 +12,7 @@
- gboolean gam_dnotify_add_subscription (GamSubscription *sub);
- gboolean gam_dnotify_remove_subscription (GamSubscription *sub);
- gboolean gam_dnotify_remove_all_for (GamListener *listener);
-+void gam_dnotify_debug (void);
-
- G_END_DECLS
-
-===================================================================
-RCS file: /cvs/gnome/gamin/server gam_inotify.c,v
-retrieving revision 1.23
-retrieving revision 1.24
-diff -u -r1.23 -r1.24
---- server/gam_inotify.c 2005/06/08 09:35:56 1.23
-+++ server/gam_inotify.c 2005/06/13 09:13:45 1.24
-@@ -44,15 +44,15 @@
- #include "gam_debugging.h"
- #endif
-
--#define MIN_POLL_TIME 1.0
--
- typedef struct {
- char *path;
- int wd;
- int refcount;
- GList *subs;
- int busy;
-- gboolean deactivated;
-+ gboolean deactivated;
-+ int events;
-+ int deactivated_events;
- } inotify_data_t;
-
- static GHashTable *path_hash = NULL;
-@@ -68,6 +68,36 @@
-
- static guint should_poll_mask = IN_MODIFY|IN_ATTRIB|IN_CLOSE_WRITE|IN_MOVED_FROM|IN_MOVED_TO|IN_DELETE|IN_CREATE|IN_DELETE_SELF|IN_UNMOUNT;
-
-+static void
-+gam_inotify_data_debug (gpointer key, gpointer value, gpointer user_data)
-+{
-+ inotify_data_t *data = (inotify_data_t *)value;
-+
-+ if (!data)
-+ return;
-+
-+ int deactivated = data->deactivated;
-+
-+ GAM_DEBUG(DEBUG_INFO, "isub wd %d refs %d busy %d deactivated %d events (%d:%d): %s\n", data->wd, data->refcount, data->busy, deactivated, data->events, data->deactivated_events, data->path);
-+}
-+
-+void
-+gam_inotify_debug(void)
-+{
-+ if (inotify_device_fd == -1)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "Inotify device not opened\n");
-+ return;
-+ }
-+
-+ if (path_hash == NULL)
-+ return;
-+
-+ GAM_DEBUG(DEBUG_INFO, "Inotify device fd = %d\n", inotify_device_fd);
-+ GAM_DEBUG(DEBUG_INFO, "Dumping inotify subscriptions\n");
-+ g_hash_table_foreach (path_hash, gam_inotify_data_debug, NULL);
-+}
-+
- static void print_mask(int mask)
- {
- if (mask & IN_ACCESS)
-@@ -138,6 +168,8 @@
- data->wd = wd;
- data->busy = 0;
- data->refcount = 1;
-+ data->deactivated_events = 0;
-+ data->events = 0;
-
- return data;
- }
-@@ -145,7 +177,7 @@
- static void
- gam_inotify_data_free(inotify_data_t * data)
- {
-- if (data->refcount != 0)
-+ if (data->refcount != 0)
- GAM_DEBUG(DEBUG_INFO, "gam_inotify_data_free called with reffed data.\n");
- g_free(data->path);
- g_free(data);
-@@ -155,11 +187,8 @@
- gam_inotify_directory_handler_internal(const char *path, pollHandlerMode mode)
- {
- inotify_data_t *data;
-- int path_fd;
-- int path_wd;
-+ int path_fd, path_wd;
- struct inotify_watch_request iwr;
--
--
- switch (mode) {
- case GAMIN_ACTIVATE:
- GAM_DEBUG(DEBUG_INFO, "Adding %s to inotify\n", path);
-@@ -178,9 +207,11 @@
- mode, path);
- return;
- }
-+
- G_LOCK(inotify);
-
- if (mode == GAMIN_ACTIVATE) {
-+
- if ((data = g_hash_table_lookup(path_hash, path)) != NULL) {
- data->refcount++;
- GAM_DEBUG(DEBUG_INFO, " found incremented refcount: %d\n",
-@@ -214,24 +245,13 @@
- gam_debug_report(GAMinotifyCreate, path, 0);
- #endif
- } else if (mode == GAMIN_DESACTIVATE) {
-- char *dir = (char *) path;
--
- data = g_hash_table_lookup(path_hash, path);
-
- if (!data) {
-- dir = g_path_get_dirname(path);
-- data = g_hash_table_lookup(path_hash, dir);
--
-- if (!data) {
-- GAM_DEBUG(DEBUG_INFO, " not found !!!\n");
-+ GAM_DEBUG(DEBUG_INFO, " not found !!!\n");
-
-- if (dir != NULL)
-- g_free(dir);
--
-- G_UNLOCK(inotify);
-- return;
-- }
-- GAM_DEBUG(DEBUG_INFO, " not found using parent\n");
-+ G_UNLOCK(inotify);
-+ return;
- }
-
- data->refcount--;
-@@ -240,46 +260,32 @@
-
- if (data->refcount == 0) {
- int wd = data->wd;
--
-- GAM_DEBUG(DEBUG_INFO, "removed inotify watch for %s\n", data->path);
--
-+ GAM_DEBUG(DEBUG_INFO, "removed inotify watch for %s\n",
-+ data->path);
- g_hash_table_remove(path_hash, data->path);
- g_hash_table_remove(wd_hash, GINT_TO_POINTER(data->wd));
- gam_inotify_data_free(data);
--
- if (ioctl (inotify_device_fd, INOTIFY_IGNORE, &wd) < 0) {
- GAM_DEBUG (DEBUG_INFO, "INOTIFY_IGNORE failed for %s (wd = %d)\n", data->path, data->wd);
- }
- #ifdef GAMIN_DEBUG_API
-- gam_debug_report(GAMinotifyDelete, dir, 0);
-+ gam_debug_report(GAMinotifyDelete, data->path, 0);
- #endif
- } else {
- GAM_DEBUG(DEBUG_INFO, " found decremented refcount: %d\n",
- data->refcount);
- #ifdef GAMIN_DEBUG_API
-- gam_debug_report(GAMinotifyChange, dir, data->refcount);
-+ gam_debug_report(GAMinotifyChange, data->path, data->refcount);
- #endif
- }
-- if ((dir != path) && (dir != NULL))
-- g_free(dir);
- } else if ((mode == GAMIN_FLOWCONTROLSTART) ||
- (mode == GAMIN_FLOWCONTROLSTOP)) {
-- char *dir = (char *) path;
--
- data = g_hash_table_lookup(path_hash, path);
- if (!data) {
-- dir = g_path_get_dirname(path);
-- data = g_hash_table_lookup(path_hash, dir);
--
-- if (!data) {
-- GAM_DEBUG(DEBUG_INFO, " not found !!!\n");
-+ GAM_DEBUG(DEBUG_INFO, " not found !!!\n");
-
-- if (dir != NULL)
-- g_free(dir);
-- G_UNLOCK(inotify);
-- return;
-- }
-- GAM_DEBUG(DEBUG_INFO, " not found using parent\n");
-+ G_UNLOCK(inotify);
-+ return;
- }
- if (data != NULL) {
- if (mode == GAMIN_FLOWCONTROLSTART) {
-@@ -292,7 +298,7 @@
- GAM_DEBUG(DEBUG_INFO, "deactivated inotify for %s\n",
- data->path);
- #ifdef GAMIN_DEBUG_API
-- gam_debug_report(GAMinotifyFlowOn, dir, 0);
-+ gam_debug_report(GAMinotifyFlowOn, data->path, 0);
- #endif
- }
- data->busy++;
-@@ -310,13 +316,11 @@
- "failed to reactivate inotify for %s\n",
- data->path);
-
-- if ((dir != path) && (dir != NULL))
-- g_free(dir);
- return;
- }
-
- iwr.fd = path_fd;
-- iwr.mask = 0xffffffff;
-+ iwr.mask = should_poll_mask;
- path_wd = ioctl (inotify_device_fd, INOTIFY_WATCH, &iwr);
- close (path_fd);
-
-@@ -338,8 +342,6 @@
- }
- }
- }
-- if ((dir != path) && (dir != NULL))
-- g_free(dir);
- } else {
- GAM_DEBUG(DEBUG_INFO, "Unimplemented operation\n");
- }
-@@ -353,17 +355,7 @@
- GAM_DEBUG(DEBUG_INFO, "gam_inotify_directory_handler %s : %d\n",
- path, mode);
-
-- if ((mode == GAMIN_DESACTIVATE) ||
-- (g_file_test(path, G_FILE_TEST_IS_DIR))) {
-- gam_inotify_directory_handler_internal(path, mode);
-- } else {
-- char *dir;
--
-- dir = g_path_get_dirname(path);
-- GAM_DEBUG(DEBUG_INFO, " not a dir using parent %s\n", dir);
-- gam_inotify_directory_handler_internal(dir, mode);
-- g_free(dir);
-- }
-+ gam_inotify_directory_handler_internal(path, mode);
- }
-
- static void
-@@ -374,15 +366,18 @@
- if (g_file_test(path, G_FILE_TEST_IS_DIR)) {
- gam_inotify_directory_handler_internal(path, mode);
- } else {
-- char *dir;
--
-- dir = g_path_get_dirname(path);
-- GAM_DEBUG(DEBUG_INFO, " not a dir using parent %s\n", dir);
-- gam_inotify_directory_handler_internal(dir, mode);
-- g_free(dir);
-+ GAM_DEBUG(DEBUG_INFO, " not a dir %s, FAILED!!!\n", path);
- }
- }
-
-+static void
-+gam_inotify_q_overflow (gpointer key, gpointer value, gpointer user_data)
-+{
-+ inotify_data_t *data = (inotify_data_t *)value;
-+
-+ gam_poll_scan_directory (data->path);
-+}
-+
- static gboolean
- gam_inotify_read_handler(gpointer user_data)
- {
-@@ -393,10 +388,6 @@
-
- G_LOCK(inotify);
-
--#if 0
-- gam_inotify_dirty_list_cleaner ();
--#endif
--
- if (ioctl(inotify_device_fd, FIONREAD, &buffer_size) < 0) {
- G_UNLOCK(inotify);
- GAM_DEBUG(DEBUG_INFO, "inotify FIONREAD < 0. kaboom!\n");
-@@ -427,6 +418,7 @@
- GAM_DEBUG(DEBUG_INFO, "processing event: inotify can't find wd %d\n", event->wd);
- } else if (data->deactivated) {
- GAM_DEBUG(DEBUG_INFO, "inotify: ignoring event on temporarily deactivated watch %s\n", data->path);
-+ data->deactivated_events++;
- } else {
- if (event->mask == IN_IGNORED) {
- GList *l;
-@@ -434,6 +426,8 @@
- GAM_DEBUG(DEBUG_INFO, "inotify: IN_IGNORE on wd=%d\n", event->wd);
- GAM_DEBUG(DEBUG_INFO, "inotify: removing all subscriptions for %s\n", data->path);
-
-+ data->events++;
-+
- l = data->subs;
- data->subs = NULL;
- for (l = l; l; l = l->next) {
-@@ -445,11 +439,12 @@
- GAM_DEBUG(DEBUG_INFO, "inotify requesting poll for %s\n", data->path);
- GAM_DEBUG(DEBUG_INFO, "poll was requested for event = ");
- print_mask (event->mask);
-+ data->events++;
- gam_poll_scan_directory (data->path);
- }
- } else if (event->mask == IN_Q_OVERFLOW) {
-- GAM_DEBUG(DEBUG_INFO, "inotify queue over flowed\n");
-- GAM_DEBUG(DEBUG_INFO, "FIXME, should request poll for all paths here\n");
-+ GAM_DEBUG(DEBUG_INFO, "inotify queue over flowed, requesting poll on all watched paths\n");
-+ g_hash_table_foreach (path_hash, gam_inotify_q_overflow, NULL);
- }
- }
-
-@@ -516,16 +511,16 @@
- {
- GSource *source;
-
-+ g_return_val_if_fail(gam_poll_init_full(FALSE), FALSE);
-+
- inotify_device_fd = open("/dev/inotify", O_RDONLY);
-
- if (inotify_device_fd < 0) {
-- GAM_DEBUG(DEBUG_INFO, "Could not open /dev/inotify\n");
-- return FALSE;
-+ GAM_DEBUG(DEBUG_INFO, "Could not open /dev/inotify\n");
-+ return FALSE;
- }
-
-- g_return_val_if_fail(gam_poll_init_full(FALSE), FALSE);
--
-- inotify_read_ioc = g_io_channel_unix_new(inotify_device_fd);
-+ inotify_read_ioc = g_io_channel_unix_new(inotify_device_fd);
-
- /* For binary data */
- g_io_channel_set_encoding(inotify_read_ioc, NULL, NULL);
-@@ -563,6 +558,7 @@
- gam_inotify_add_subscription(GamSubscription * sub)
- {
- GAM_DEBUG(DEBUG_INFO, "gam_inotify_add_subscription\n");
-+
- if (!gam_poll_add_subscription(sub)) {
- return FALSE;
- }
-===================================================================
-RCS file: /cvs/gnome/gamin/server gam_inotify.h,v
-retrieving revision 1.2
-retrieving revision 1.3
-diff -u -r1.2 -r1.3
---- server/gam_inotify.h 2005/04/15 11:17:38 1.2
-+++ server/gam_inotify.h 2005/06/13 09:13:45 1.3
-@@ -11,6 +11,7 @@
- gboolean gam_inotify_add_subscription (GamSubscription *sub);
- gboolean gam_inotify_remove_subscription (GamSubscription *sub);
- gboolean gam_inotify_remove_all_for (GamListener *listener);
-+void gam_inotify_debug (void);
-
- G_END_DECLS
-
-===================================================================
-RCS file: /cvs/gnome/gamin/server gam_poll.c,v
-retrieving revision 1.56
-retrieving revision 1.57
-diff -u -r1.56 -r1.57
---- server/gam_poll.c 2005/06/10 14:31:33 1.56
-+++ server/gam_poll.c 2005/06/13 09:13:45 1.57
-@@ -149,7 +149,7 @@
- static void
- trigger_dir_handler(const char *path, pollHandlerMode mode, GamNode * node)
- {
-- if (type_khandler == GAMIN_K_DNOTIFY) {
-+ if (type_khandler == GAMIN_K_DNOTIFY || type_khandler == GAMIN_K_INOTIFY) {
- if (gam_node_is_dir(node)) {
- if (dir_handler != NULL)
- (*dir_handler) (path, mode);
-@@ -172,7 +172,7 @@
- static void
- trigger_file_handler(const char *path, pollHandlerMode mode, GamNode * node)
- {
-- if (type_khandler == GAMIN_K_DNOTIFY) {
-+ if (type_khandler == GAMIN_K_DNOTIFY || type_khandler == GAMIN_K_INOTIFY) {
- if (gam_node_is_dir(node)) {
- (*file_handler) (path, mode);
- } else {
-@@ -947,8 +947,14 @@
- gboolean
- gam_poll_init_full(gboolean start_scan_thread)
- {
-+ /* already started */
-+ if ((poll_mode == 2) && (start_scan_thread))
-+ return (TRUE);
-+ if ((poll_mode == 1) && (!start_scan_thread))
-+ return (TRUE);
-+ /* not started as expected */
- if (poll_mode != 0)
-- return (FALSE);
-+ return(FALSE);
-
- if (!start_scan_thread) {
- g_timeout_add(1000, gam_poll_scan_callback, NULL);
-===================================================================
-RCS file: /cvs/gnome/gamin/server gam_server.c,v
-retrieving revision 1.24
-retrieving revision 1.25
-diff -u -r1.24 -r1.25
---- server/gam_server.c 2005/06/08 22:07:51 1.24
-+++ server/gam_server.c 2005/06/13 09:13:45 1.25
-@@ -82,6 +82,12 @@
- void
- gam_show_debug(void) {
- gam_connections_debug();
-+#ifdef ENABLE_INOTIFY
-+ gam_inotify_debug ();
-+#endif
-+#ifdef ENABLE_DNOTIFY
-+ gam_dnotify_debug ();
-+#endif
- }
-
- /**
-===================================================================
-RCS file: /cvs/gnome/gamin/tests testing.c,v
-retrieving revision 1.10
-retrieving revision 1.11
-diff -u -r1.10 -r1.11
---- tests/testing.c 2005/04/04 11:51:38 1.10
-+++ tests/testing.c 2005/06/13 09:13:45 1.11
-@@ -313,7 +313,7 @@
- testState.nb_requests++;
- } else if (!strcmp(command, "monfile")) {
- if (args != 2) {
-- fprintf(stderr, "mkdir line %d: lacks name\n", no);
-+ fprintf(stderr, "monfile line %d: lacks name\n", no);
- return (-1);
- }
- if (arg[0] != '/')
diff --git a/app-admin/gamin/files/gamin-0.1.2-freebsd.patch b/app-admin/gamin/files/gamin-0.1.2-freebsd.patch
deleted file mode 100644
index 67cb6bd499e7..000000000000
--- a/app-admin/gamin/files/gamin-0.1.2-freebsd.patch
+++ /dev/null
@@ -1,124 +0,0 @@
-diff -ur -x '*~' gamin-0.1.2/libgamin/gam_api.c gamin-0.1.2-fbsd/libgamin/gam_api.c
---- gamin-0.1.2/libgamin/gam_api.c 2005-06-15 12:53:25.000000000 +0200
-+++ gamin-0.1.2-fbsd/libgamin/gam_api.c 2005-07-16 00:15:37.317345328 +0200
-@@ -421,7 +421,7 @@
- {
- char data[2] = { 0, 0 };
- int written;
--#if defined(HAVE_CMSGCRED) && !defined(LOCAL_CREDS)
-+#if defined(HAVE_CMSGCRED) && (!defined(LOCAL_CREDS) || defined(__FreeBSD__))
- struct {
- struct cmsghdr hdr;
- struct cmsgcred cred;
-@@ -445,7 +445,7 @@
- #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);
-@@ -655,7 +655,7 @@
-
- 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;
-Only in gamin-0.1.2-fbsd/libgamin: gam_api.c.orig
-diff -ur -x '*~' gamin-0.1.2/libgamin/gam_data.c gamin-0.1.2-fbsd/libgamin/gam_data.c
---- gamin-0.1.2/libgamin/gam_data.c 2005-05-18 16:45:04.000000000 +0200
-+++ gamin-0.1.2-fbsd/libgamin/gam_data.c 2005-07-16 12:06:58.586806112 +0200
-@@ -17,6 +17,10 @@
- #ifdef HAVE_PTHREAD_H
- #include <pthread.h>
-
-+# ifdef __GLIBC__
-+# define PTHREAD_MUTEX_RECURSIVE PTHREAD_MUTEX_RECURSIVE_NP
-+# endif
-+
- static int is_threaded = -1;
- #endif
-
-@@ -471,7 +475,7 @@
- }
- if (is_threaded > 0) {
- pthread_mutexattr_init(&attr);
-- pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_RECURSIVE_NP);
-+ pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_RECURSIVE);
- pthread_mutex_init(&ret->lock, &attr);
- pthread_mutexattr_destroy(&attr);
- }
-diff -ur -x '*~' gamin-0.1.2/server/gam_channel.c gamin-0.1.2-fbsd/server/gam_channel.c
---- gamin-0.1.2/server/gam_channel.c 2005-06-15 13:02:34.000000000 +0200
-+++ gamin-0.1.2-fbsd/server/gam_channel.c 2005-07-16 00:15:37.326343960 +0200
-@@ -29,7 +29,7 @@
- {
- char data[2] = { 0, 0 };
- int written;
--#if defined(HAVE_CMSGCRED) && !defined(LOCAL_CREDS)
-+#if defined(HAVE_CMSGCRED) && (!defined(LOCAL_CREDS) || defined(__FreeBSD__))
- struct {
- struct cmsghdr hdr;
- struct cmsgcred cred;
-@@ -53,7 +53,7 @@
- #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);
-@@ -100,7 +100,7 @@
-
- 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;
-diff -ur -x '*~' gamin-0.1.2/server/gam_connection.c gamin-0.1.2-fbsd/server/gam_connection.c
---- gamin-0.1.2/server/gam_connection.c 2005-06-14 14:31:19.000000000 +0200
-+++ gamin-0.1.2-fbsd/server/gam_connection.c 2005-07-16 00:15:37.332343048 +0200
-@@ -30,10 +30,7 @@
- GMainLoop *loop; /* the Glib loop used */
- GIOChannel *source; /* the Glib I/O Channel used */
- int request_len; /* how many bytes of request are valid */
-- union {
-- GAMPacket request; /* the next request being read */
-- void *request_data; /* the next request as a char * */
-- };
-+ GAMPacket request; /* the next request being read */
- GamListener *listener; /* the listener associated with the connection */
- };
-
-@@ -245,7 +242,7 @@
- g_assert(data);
- g_assert(size);
-
-- *data = (char *) &conn->request_data + conn->request_len;
-+ *data = (char *) &conn->request + conn->request_len;
- *size = sizeof(GAMPacket) - conn->request_len;
-
- return (0);
-diff -ur -x '*~' gamin-0.1.2/tests/testing.c gamin-0.1.2-fbsd/tests/testing.c
---- gamin-0.1.2/tests/testing.c 2005-06-13 10:59:29.000000000 +0200
-+++ gamin-0.1.2-fbsd/tests/testing.c 2005-07-16 00:15:37.337342288 +0200
-@@ -436,9 +436,9 @@
- 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); */
-Only in gamin-0.1.2-fbsd/tests: testing.c.orig
diff --git a/app-admin/gamin/files/gamin-0.1.2-inotify-legacy-backend.patch b/app-admin/gamin/files/gamin-0.1.2-inotify-legacy-backend.patch
deleted file mode 100644
index b7a735d38341..000000000000
--- a/app-admin/gamin/files/gamin-0.1.2-inotify-legacy-backend.patch
+++ /dev/null
@@ -1,884 +0,0 @@
-Add support for INotify Legacy backend (pre 0.24)
-
-diff -urpN gamin-0.1.2/configure.in gamin-0.1.2.az/configure.in
---- gamin-0.1.2/configure.in 2005-07-13 13:10:43.000000000 +0200
-+++ gamin-0.1.2.az/configure.in 2005-07-16 09:23:22.000000000 +0200
-@@ -225,16 +225,41 @@ dnl check if inotify backend is enabled
- AM_CONDITIONAL(ENABLE_INOTIFY, test x$inotify = xtrue)
-
- if test x$inotify = xtrue; then
-- AC_CHECK_HEADERS(linux/inotify.h)
-+ AC_CHECK_HEADERS(linux/inotify.h,
-+ [AC_CHECK_DECL(INOTIFY_IOCTL_MAGIC,
-+ [AC_DEFINE(HAVE_INOTIFY_IOCTL_MAGIC,1,[Have legacy linux/inotify.h])],
-+ [],[#include <linux/inotify.h>])])
- AC_DEFINE(ENABLE_INOTIFY,1,[Use inotify as backend])
- backends="${backends}, inotify"
- fi
-
-+if test x$os = xlinux-gnu; then
-+ AC_ARG_ENABLE(inotify-legacy,
-+ [ --enable-inotify-legacy Enable the INotify Legacy backend],
-+ [case "${enableval}" in
-+ yes) inotify_legacy=true ;;
-+ no) inotify_legacy=false;;
-+ *) AC_MSG_ERROR(bad value ${enableval} for --enable-inotify-legacy) ;;
-+ esac],[inotify_legacy=false])
-+fi
-+
-+dnl check if inotify legacy backend is enabled
-+AM_CONDITIONAL(ENABLE_INOTIFY_LEGACY, test x$inotify_legacy = xtrue)
-+
-+if test x$inotify_legacy = xtrue; then
-+ AC_CHECK_HEADERS(linux/inotify.h,
-+ [AC_CHECK_DECL(INOTIFY_IOCTL_MAGIC,
-+ [AC_DEFINE(HAVE_INOTIFY_IOCTL_MAGIC,1,[Have legacy linux/inotify.h])],
-+ [],[#include <linux/inotify.h>])])
-+ AC_DEFINE(ENABLE_INOTIFY_LEGACY,1,[Use inotify legacy as backend])
-+ backends="${backends}, inotify_legacy"
-+fi
-+
- if test x$os != xBogusOS; then
- AC_CHECK_FUNC(kevent,[have_kevent=1],)
- if test x$have_kevent = x1 ; then
- AC_ARG_ENABLE(kqueue,
-- [ --disable-kqueue Disable the KQueue backend],
-+ [ --disable-kqueue Disable the KQueue backend],
- [case "${enableval}" in
- yes) kqueue=true ;;
- no) kqueue=false ;;
-diff -urpN gamin-0.1.2/server/Makefile.am gamin-0.1.2.az/server/Makefile.am
---- gamin-0.1.2/server/Makefile.am 2005-06-08 23:48:00.000000000 +0200
-+++ gamin-0.1.2.az/server/Makefile.am 2005-07-16 09:26:06.000000000 +0200
-@@ -38,6 +38,7 @@ gam_server_SOURCES = \
- gam_excludes.c \
- gam_excludes.h \
- local_inotify.h \
-+ local_inotify_legacy.h \
- gam_debug_lists.c \
- server_config.h
-
-@@ -45,6 +46,10 @@ if ENABLE_INOTIFY
- gam_server_SOURCES += gam_inotify.c gam_inotify.h
- endif
-
-+if ENABLE_INOTIFY_LEGACY
-+gam_server_SOURCES += gam_inotify_legacy.c gam_inotify_legacy.h
-+endif
-+
- if ENABLE_DNOTIFY
- gam_server_SOURCES += gam_dnotify.c gam_dnotify.h
- endif
-diff -urpN gamin-0.1.2/server/gam_inotify.c gamin-0.1.2.az/server/gam_inotify.c
---- gamin-0.1.2/server/gam_inotify.c 2005-07-12 23:15:19.000000000 +0200
-+++ gamin-0.1.2.az/server/gam_inotify.c 2005-07-16 09:24:31.000000000 +0200
-@@ -31,7 +31,7 @@
- #include <glib.h>
- #include "gam_error.h"
- #include "gam_poll.h"
--#ifdef HAVE_LINUX_INOTIFY_H
-+#if defined(HAVE_LINUX_INOTIFY_H) && !defined(HAVE_INOTIFY_IOCTL_MAGIC)
- #include <linux/inotify.h>
- #else
- #include "local_inotify.h"
-diff -urpN gamin-0.1.2/server/gam_inotify_legacy.c gamin-0.1.2.az/server/gam_inotify_legacy.c
---- gamin-0.1.2/server/gam_inotify_legacy.c 1970-01-01 02:00:00.000000000 +0200
-+++ gamin-0.1.2.az/server/gam_inotify_legacy.c 2005-07-16 09:36:47.000000000 +0200
-@@ -0,0 +1,611 @@
-+/* gamin inotify_legacy backend
-+ * Copyright (C) 2005 John McCutchan
-+ *
-+ * Based off of code,
-+ * Copyright (C) 2003 James Willcox, Corey Bowers
-+ *
-+ * This library is free software; you can redistribute it and/or
-+ * modify it under the terms of the GNU Lesser General Public
-+ * License as published by the Free Software Foundation; either
-+ * version 2 of the License, or (at your option) any later version.
-+ *
-+ * This library 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
-+ * Lesser General Public License for more details.
-+ *
-+ * You should have received a copy of the GNU Lesser General Public
-+ * License along with this library; if not, write to the Free
-+ * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-+ */
-+
-+
-+#include "server_config.h"
-+#define _GNU_SOURCE
-+#include <fcntl.h>
-+#include <signal.h>
-+#include <unistd.h>
-+#include <sys/ioctl.h>
-+#include <stdio.h>
-+#include <glib.h>
-+#include "gam_error.h"
-+#include "gam_poll.h"
-+#if defined(HAVE_LINUX_INOTIFY_H) && defined(HAVE_INOTIFY_IOCTL_MAGIC)
-+#include <linux/inotify.h>
-+#else
-+#include "local_inotify_legacy.h"
-+#endif
-+#include "gam_inotify_legacy.h"
-+#include "gam_tree.h"
-+#include "gam_event.h"
-+#include "gam_server.h"
-+#include "gam_event.h"
-+#ifdef GAMIN_DEBUG_API
-+#include "gam_debugging.h"
-+#endif
-+
-+typedef struct {
-+ char *path;
-+ int wd;
-+ int refcount;
-+ GList *subs;
-+ int busy;
-+ gboolean deactivated;
-+ int events;
-+ int deactivated_events;
-+} inotify_legacy_data_t;
-+
-+static GHashTable *path_hash = NULL;
-+static GHashTable *wd_hash = NULL;
-+
-+G_LOCK_DEFINE_STATIC(inotify_legacy);
-+
-+static GIOChannel *inotify_legacy_read_ioc = NULL;
-+
-+static gboolean have_consume_idler = FALSE;
-+
-+static int inotify_legacy_device_fd = -1;
-+
-+static guint should_poll_mask = IN_MODIFY|IN_ATTRIB|IN_CLOSE_WRITE|IN_MOVED_FROM|IN_MOVED_TO|IN_DELETE|IN_CREATE|IN_DELETE_SELF|IN_UNMOUNT;
-+
-+static void
-+gam_inotify_legacy_data_debug (gpointer key, gpointer value, gpointer user_data)
-+{
-+ inotify_legacy_data_t *data = (inotify_legacy_data_t *)value;
-+
-+ if (!data)
-+ return;
-+
-+ int deactivated = data->deactivated;
-+
-+ GAM_DEBUG(DEBUG_INFO, "isub wd %d refs %d busy %d deactivated %d events (%d:%d): %s\n", data->wd, data->refcount, data->busy, deactivated, data->events, data->deactivated_events, data->path);
-+}
-+
-+void
-+gam_inotify_legacy_debug(void)
-+{
-+ if (inotify_legacy_device_fd == -1)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "Inotify device not opened\n");
-+ return;
-+ }
-+
-+ if (path_hash == NULL)
-+ return;
-+
-+ GAM_DEBUG(DEBUG_INFO, "Inotify device fd = %d\n", inotify_legacy_device_fd);
-+ GAM_DEBUG(DEBUG_INFO, "Dumping inotify_legacy subscriptions\n");
-+ g_hash_table_foreach (path_hash, gam_inotify_legacy_data_debug, NULL);
-+}
-+
-+static void print_mask(int mask)
-+{
-+ if (mask & IN_ACCESS)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "ACCESS\n");
-+ }
-+ if (mask & IN_MODIFY)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "MODIFY\n");
-+ }
-+ if (mask & IN_ATTRIB)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "ATTRIB\n");
-+ }
-+ if (mask & IN_CLOSE_WRITE)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "CLOSE_WRITE\n");
-+ }
-+ if (mask & IN_CLOSE_NOWRITE)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "CLOSE_WRITE\n");
-+ }
-+ if (mask & IN_OPEN)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "OPEN\n");
-+ }
-+ if (mask & IN_MOVED_FROM)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "MOVE_FROM\n");
-+ }
-+ if (mask & IN_MOVED_TO)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "MOVE_TO\n");
-+ }
-+ if (mask & IN_DELETE)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "DELETE\n");
-+ }
-+ if (mask & IN_CREATE)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "CREATE_SUBDIR\n");
-+ }
-+ if (mask & IN_DELETE_SELF)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "DELETE_SELF\n");
-+ }
-+ if (mask & IN_UNMOUNT)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "UNMOUNT\n");
-+ }
-+ if (mask & IN_Q_OVERFLOW)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "Q_OVERFLOW\n");
-+ }
-+ if (mask & IN_IGNORED)
-+ {
-+ GAM_DEBUG(DEBUG_INFO, "IGNORED\n");
-+ }
-+}
-+
-+static inotify_legacy_data_t *
-+gam_inotify_legacy_data_new(const char *path, int wd)
-+{
-+ inotify_legacy_data_t *data;
-+
-+ data = g_new0(inotify_legacy_data_t, 1);
-+ data->path = g_strdup(path);
-+ data->wd = wd;
-+ data->busy = 0;
-+ data->refcount = 1;
-+ data->deactivated_events = 0;
-+ data->events = 0;
-+
-+ return data;
-+}
-+
-+static void
-+gam_inotify_legacy_data_free(inotify_legacy_data_t * data)
-+{
-+ if (data->refcount != 0)
-+ GAM_DEBUG(DEBUG_INFO, "gam_inotify_legacy_data_free called with reffed data.\n");
-+ g_free(data->path);
-+ g_free(data);
-+}
-+
-+static void
-+gam_inotify_legacy_directory_handler_internal(const char *path, pollHandlerMode mode)
-+{
-+ inotify_legacy_data_t *data;
-+ int path_fd, path_wd;
-+ struct inotify_watch_request iwr;
-+ switch (mode) {
-+ case GAMIN_ACTIVATE:
-+ GAM_DEBUG(DEBUG_INFO, "Adding %s to inotify_legacy\n", path);
-+ break;
-+ case GAMIN_DESACTIVATE:
-+ GAM_DEBUG(DEBUG_INFO, "Removing %s from inotify_legacy\n", path);
-+ break;
-+ case GAMIN_FLOWCONTROLSTART:
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy: Start flow control for %s\n", path);
-+ break;
-+ case GAMIN_FLOWCONTROLSTOP:
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy: Stop flow control for %s\n", path);
-+ break;
-+ default:
-+ gam_error(DEBUG_INFO, "Unknown inotify_legacy operation %d for %s\n",
-+ mode, path);
-+ return;
-+ }
-+
-+ G_LOCK(inotify_legacy);
-+
-+ if (mode == GAMIN_ACTIVATE) {
-+
-+ if ((data = g_hash_table_lookup(path_hash, path)) != NULL) {
-+ data->refcount++;
-+ GAM_DEBUG(DEBUG_INFO, " found incremented refcount: %d\n",
-+ data->refcount);
-+ G_UNLOCK(inotify_legacy);
-+#ifdef GAMIN_DEBUG_API
-+ gam_debug_report(GAMinotifyChange, path, data->refcount);
-+#endif
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy updated refcount\n");
-+ return;
-+ }
-+
-+ path_fd = open(path, O_RDONLY);
-+
-+ if (path_fd < 0) {
-+ G_UNLOCK(inotify_legacy);
-+ return;
-+ }
-+
-+ iwr.fd = path_fd;
-+ iwr.mask = should_poll_mask;
-+ path_wd = ioctl (inotify_legacy_device_fd, INOTIFY_WATCH, &iwr);
-+ close (path_fd);
-+
-+ data = gam_inotify_legacy_data_new(path, path_wd);
-+ g_hash_table_insert(wd_hash, GINT_TO_POINTER(data->wd), data);
-+ g_hash_table_insert(path_hash, data->path, data);
-+
-+ GAM_DEBUG(DEBUG_INFO, "activated inotify_legacy for %s\n", path);
-+#ifdef GAMIN_DEBUG_API
-+ gam_debug_report(GAMinotifyCreate, path, 0);
-+#endif
-+ } else if (mode == GAMIN_DESACTIVATE) {
-+ data = g_hash_table_lookup(path_hash, path);
-+
-+ if (!data) {
-+ GAM_DEBUG(DEBUG_INFO, " not found !!!\n");
-+
-+ G_UNLOCK(inotify_legacy);
-+ return;
-+ }
-+
-+ data->refcount--;
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy decremeneted refcount for %s\n",
-+ path);
-+
-+ if (data->refcount == 0) {
-+ int wd = data->wd;
-+ GAM_DEBUG(DEBUG_INFO, "removed inotify_legacy watch for %s\n",
-+ data->path);
-+ g_hash_table_remove(path_hash, data->path);
-+ g_hash_table_remove(wd_hash, GINT_TO_POINTER(data->wd));
-+ gam_inotify_legacy_data_free(data);
-+ if (ioctl (inotify_legacy_device_fd, INOTIFY_IGNORE, &wd) < 0) {
-+ GAM_DEBUG (DEBUG_INFO, "INOTIFY_IGNORE failed for %s (wd = %d)\n", data->path, data->wd);
-+ }
-+#ifdef GAMIN_DEBUG_API
-+ gam_debug_report(GAMinotifyDelete, data->path, 0);
-+#endif
-+ } else {
-+ GAM_DEBUG(DEBUG_INFO, " found decremented refcount: %d\n",
-+ data->refcount);
-+#ifdef GAMIN_DEBUG_API
-+ gam_debug_report(GAMinotifyChange, data->path, data->refcount);
-+#endif
-+ }
-+ } else if ((mode == GAMIN_FLOWCONTROLSTART) ||
-+ (mode == GAMIN_FLOWCONTROLSTOP)) {
-+ data = g_hash_table_lookup(path_hash, path);
-+ if (!data) {
-+ GAM_DEBUG(DEBUG_INFO, " not found !!!\n");
-+
-+ G_UNLOCK(inotify_legacy);
-+ return;
-+ }
-+ if (data != NULL) {
-+ if (mode == GAMIN_FLOWCONTROLSTART) {
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy: GAMIN_FLOWCONTROLSTART for %s\n", data->path);
-+ if (data->wd >= 0) {
-+ if (ioctl (inotify_legacy_device_fd, INOTIFY_IGNORE, &data->wd) < 0) {
-+ GAM_DEBUG (DEBUG_INFO, "INOTIFY_IGNORE failed for %s (wd = %d)\n", data->path, data->wd);
-+ }
-+ data->deactivated = TRUE;
-+ GAM_DEBUG(DEBUG_INFO, "deactivated inotify_legacy for %s\n",
-+ data->path);
-+#ifdef GAMIN_DEBUG_API
-+ gam_debug_report(GAMinotifyFlowOn, data->path, 0);
-+#endif
-+ }
-+ data->busy++;
-+ } else {
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy: GAMIN_FLOWCONTROLSTOP for %s\n", data->path);
-+ if (data->busy > 0) {
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy: data->busy > 0 for %s\n", data->path);
-+ data->busy--;
-+ if (data->busy == 0) {
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy: data->busy == 0 for %s\n", data->path);
-+ path_fd = open(data->path, O_RDONLY);
-+ if (path_fd < 0) {
-+ G_UNLOCK(inotify_legacy);
-+ GAM_DEBUG(DEBUG_INFO,
-+ "failed to reactivate inotify_legacy for %s\n",
-+ data->path);
-+
-+ return;
-+ }
-+
-+ iwr.fd = path_fd;
-+ iwr.mask = should_poll_mask;
-+ path_wd = ioctl (inotify_legacy_device_fd, INOTIFY_WATCH, &iwr);
-+ close (path_fd);
-+
-+ /* Remove the old wd from the hash table */
-+ g_hash_table_remove(wd_hash, GINT_TO_POINTER(data->wd));
-+
-+ data->wd = path_wd;
-+ data->deactivated = FALSE;
-+
-+ /* Insert the new wd into the hash table */
-+ g_hash_table_insert(wd_hash, GINT_TO_POINTER(data->wd),
-+ data);
-+ GAM_DEBUG(DEBUG_INFO, "reactivated inotify_legacy for %s\n",
-+ data->path);
-+#ifdef GAMIN_DEBUG_API
-+ gam_debug_report(GAMinotifyFlowOff, path, 0);
-+#endif
-+ }
-+ }
-+ }
-+ }
-+ } else {
-+ GAM_DEBUG(DEBUG_INFO, "Unimplemented operation\n");
-+ }
-+
-+ G_UNLOCK(inotify_legacy);
-+}
-+
-+static void
-+gam_inotify_legacy_directory_handler(const char *path, pollHandlerMode mode)
-+{
-+ GAM_DEBUG(DEBUG_INFO, "gam_inotify_legacy_directory_handler %s : %d\n",
-+ path, mode);
-+
-+ gam_inotify_legacy_directory_handler_internal(path, mode);
-+}
-+
-+static void
-+gam_inotify_legacy_file_handler(const char *path, pollHandlerMode mode)
-+{
-+ GAM_DEBUG(DEBUG_INFO, "gam_inotify_legacy_file_handler %s : %d\n", path, mode);
-+
-+ if (g_file_test(path, G_FILE_TEST_IS_DIR)) {
-+ gam_inotify_legacy_directory_handler_internal(path, mode);
-+ } else {
-+ GAM_DEBUG(DEBUG_INFO, " not a dir %s, FAILED!!!\n", path);
-+ }
-+}
-+
-+static void
-+gam_inotify_legacy_q_overflow (gpointer key, gpointer value, gpointer user_data)
-+{
-+ inotify_legacy_data_t *data = (inotify_legacy_data_t *)value;
-+
-+ gam_poll_scan_directory (data->path);
-+}
-+
-+static gboolean
-+gam_inotify_legacy_read_handler(gpointer user_data)
-+{
-+ char *buffer;
-+ int buffer_size;
-+ int events;
-+ gsize buffer_i, read_size;
-+
-+ G_LOCK(inotify_legacy);
-+
-+ if (ioctl(inotify_legacy_device_fd, FIONREAD, &buffer_size) < 0) {
-+ G_UNLOCK(inotify_legacy);
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy FIONREAD < 0. kaboom!\n");
-+ return FALSE;
-+ }
-+
-+ buffer = g_malloc(buffer_size);
-+
-+ if (g_io_channel_read_chars(inotify_legacy_read_ioc, (char *)buffer, buffer_size, &read_size, NULL) != G_IO_STATUS_NORMAL) {
-+ G_UNLOCK(inotify_legacy);
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy failed to read events from inotify_legacy fd.\n");
-+ g_free (buffer);
-+ return FALSE;
-+ }
-+
-+ buffer_i = 0;
-+ events = 0;
-+ while (buffer_i < read_size) {
-+ struct inotify_event *event;
-+ gsize event_size;
-+ inotify_legacy_data_t *data;
-+
-+ event = (struct inotify_event *)&buffer[buffer_i];
-+ event_size = sizeof(struct inotify_event) + event->len;
-+
-+ data = g_hash_table_lookup (wd_hash, GINT_TO_POINTER(event->wd));
-+ if (!data) {
-+ GAM_DEBUG(DEBUG_INFO, "processing event: inotify_legacy can't find wd %d\n", event->wd);
-+ } else if (data->deactivated) {
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy: ignoring event on temporarily deactivated watch %s\n", data->path);
-+ data->deactivated_events++;
-+ } else {
-+ if (event->mask == IN_IGNORED) {
-+ GList *l;
-+
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy: IN_IGNORE on wd=%d\n", event->wd);
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy: removing all subscriptions for %s\n", data->path);
-+
-+ data->events++;
-+
-+ l = data->subs;
-+ data->subs = NULL;
-+ for (l = l; l; l = l->next) {
-+ GamSubscription *sub = l->data;
-+ gam_inotify_legacy_remove_subscription (sub);
-+ }
-+ } else if (event->mask != IN_Q_OVERFLOW) {
-+ if (event->mask & should_poll_mask) {
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy requesting poll for %s\n", data->path);
-+ GAM_DEBUG(DEBUG_INFO, "poll was requested for event = ");
-+ print_mask (event->mask);
-+ data->events++;
-+ gam_poll_scan_directory (data->path);
-+ }
-+ } else if (event->mask == IN_Q_OVERFLOW) {
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy queue over flowed, requesting poll on all watched paths\n");
-+ g_hash_table_foreach (path_hash, gam_inotify_legacy_q_overflow, NULL);
-+ }
-+ }
-+
-+ buffer_i += event_size;
-+ events++;
-+ }
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy recieved %d events\n", events);
-+
-+ g_free(buffer);
-+ G_UNLOCK(inotify_legacy);
-+
-+ return TRUE;
-+}
-+
-+
-+static gboolean
-+gam_inotify_legacy_consume_subscriptions_real(gpointer data)
-+{
-+ GAM_DEBUG(DEBUG_INFO, "gam_inotify_legacy_consume_subscriptions_real()\n");
-+ gam_poll_consume_subscriptions();
-+ have_consume_idler = FALSE;
-+ return FALSE;
-+}
-+
-+static void
-+gam_inotify_legacy_consume_subscriptions(void)
-+{
-+ GSource *source;
-+
-+ if (have_consume_idler)
-+ return;
-+
-+ GAM_DEBUG(DEBUG_INFO, "gam_inotify_legacy_consume_subscriptions()\n");
-+ have_consume_idler = TRUE;
-+ source = g_idle_source_new();
-+ g_source_set_callback(source, gam_inotify_legacy_consume_subscriptions_real,
-+ NULL, NULL);
-+ g_source_attach(source, NULL);
-+}
-+
-+/**
-+ * @defgroup inotify_legacy inotify_legacy Backend
-+ * @ingroup Backends
-+ * @brief inotify_legacy backend API
-+ *
-+ * Since version 2.6.X, Linux kernels have included the Linux Inode
-+ * Notification system (inotify_legacy). This backend uses inotify_legacy to know when
-+ * files are changed/created/deleted. Since inotify_legacy can't watch files/dirs that
-+ * don't exist we still have to cache stat() information. For this,
-+ * we can just use the code in the polling backend.
-+ *
-+ * @{
-+ */
-+
-+
-+/**
-+ * Initializes the inotify_legacy backend. This must be called before
-+ * any other functions in this module.
-+ *
-+ * @returns TRUE if initialization succeeded, FALSE otherwise
-+ */
-+gboolean
-+gam_inotify_legacy_init(void)
-+{
-+ GSource *source;
-+
-+ g_return_val_if_fail(gam_poll_init_full(FALSE), FALSE);
-+
-+ inotify_legacy_device_fd = open("/dev/inotify", O_RDONLY);
-+
-+ if (inotify_legacy_device_fd < 0) {
-+ GAM_DEBUG(DEBUG_INFO, "Could not open /dev/inotify\n");
-+ return FALSE;
-+ }
-+
-+ inotify_legacy_read_ioc = g_io_channel_unix_new(inotify_legacy_device_fd);
-+
-+ /* For binary data */
-+ g_io_channel_set_encoding(inotify_legacy_read_ioc, NULL, NULL);
-+ /* Non blocking */
-+ g_io_channel_set_flags(inotify_legacy_read_ioc, G_IO_FLAG_NONBLOCK, NULL);
-+
-+ source = g_io_create_watch(inotify_legacy_read_ioc,
-+ G_IO_IN | G_IO_HUP | G_IO_ERR);
-+ g_source_set_callback(source, gam_inotify_legacy_read_handler, NULL, NULL);
-+
-+ g_source_attach(source, NULL);
-+
-+ path_hash = g_hash_table_new(g_str_hash, g_str_equal);
-+ wd_hash = g_hash_table_new(g_direct_hash, g_direct_equal);
-+ gam_poll_set_kernel_handler(gam_inotify_legacy_directory_handler,
-+ gam_inotify_legacy_file_handler,
-+ GAMIN_K_INOTIFY);
-+
-+ GAM_DEBUG(DEBUG_INFO, "inotify_legacy initialized\n");
-+
-+ gam_backend_add_subscription = gam_inotify_legacy_add_subscription;
-+ gam_backend_remove_subscription = gam_inotify_legacy_remove_subscription;
-+ gam_backend_remove_all_for = gam_inotify_legacy_remove_all_for;
-+
-+ return TRUE;
-+}
-+
-+/**
-+ * Adds a subscription to be monitored.
-+ *
-+ * @param sub a #GamSubscription to be polled
-+ * @returns TRUE if adding the subscription succeeded, FALSE otherwise
-+ */
-+gboolean
-+gam_inotify_legacy_add_subscription(GamSubscription * sub)
-+{
-+ GAM_DEBUG(DEBUG_INFO, "gam_inotify_legacy_add_subscription\n");
-+
-+ if (!gam_poll_add_subscription(sub)) {
-+ return FALSE;
-+ }
-+
-+ gam_inotify_legacy_consume_subscriptions();
-+
-+ GAM_DEBUG(DEBUG_INFO, "gam_inotify_legacy_add_subscription: done\n");
-+ return TRUE;
-+}
-+
-+/**
-+ * Removes a subscription which was being monitored.
-+ *
-+ * @param sub a #GamSubscription to remove
-+ * @returns TRUE if removing the subscription succeeded, FALSE otherwise
-+ */
-+gboolean
-+gam_inotify_legacy_remove_subscription(GamSubscription * sub)
-+{
-+ GAM_DEBUG(DEBUG_INFO, "gam_inotify_legacy_remove_subscription\n");
-+
-+ if (!gam_poll_remove_subscription(sub)) {
-+ return FALSE;
-+ }
-+
-+ gam_inotify_legacy_consume_subscriptions();
-+
-+ GAM_DEBUG(DEBUG_INFO, "gam_inotify_legacy_remove_subscription: done\n");
-+ return TRUE;
-+}
-+
-+/**
-+ * Stop monitoring all subscriptions for a given listener.
-+ *
-+ * @param listener a #GamListener
-+ * @returns TRUE if removing the subscriptions succeeded, FALSE otherwise
-+ */
-+gboolean
-+gam_inotify_legacy_remove_all_for(GamListener * listener)
-+{
-+ if (!gam_poll_remove_all_for(listener)) {
-+ return FALSE;
-+ }
-+
-+ gam_inotify_legacy_consume_subscriptions();
-+
-+ return TRUE;
-+}
-+
-+/** @} */
-diff -urpN gamin-0.1.2/server/gam_inotify_legacy.h gamin-0.1.2.az/server/gam_inotify_legacy.h
---- gamin-0.1.2/server/gam_inotify_legacy.h 1970-01-01 02:00:00.000000000 +0200
-+++ gamin-0.1.2.az/server/gam_inotify_legacy.h 2005-07-16 08:41:34.000000000 +0200
-@@ -0,0 +1,18 @@
-+#ifndef __GAM_INOTIFY_LEGACY_H__
-+#define __GAM_INOTIFY_LEGACY_H__
-+
-+#include <glib.h>
-+#include "gam_poll.h"
-+#include "gam_subscription.h"
-+
-+G_BEGIN_DECLS
-+
-+gboolean gam_inotify_legacy_init (void);
-+gboolean gam_inotify_legacy_add_subscription (GamSubscription *sub);
-+gboolean gam_inotify_legacy_remove_subscription (GamSubscription *sub);
-+gboolean gam_inotify_legacy_remove_all_for (GamListener *listener);
-+void gam_inotify_legacy_debug (void);
-+
-+G_END_DECLS
-+
-+#endif /* __GAM_INOTIFY_LEGACY_H__ */
-diff -urpN gamin-0.1.2/server/gam_server.c gamin-0.1.2.az/server/gam_server.c
---- gamin-0.1.2/server/gam_server.c 2005-06-15 13:02:34.000000000 +0200
-+++ gamin-0.1.2.az/server/gam_server.c 2005-07-16 08:44:19.000000000 +0200
-@@ -36,6 +36,9 @@
- #ifdef ENABLE_INOTIFY
- #include "gam_inotify.h"
- #endif
-+#ifdef ENABLE_INOTIFY_LEGACY
-+#include "gam_inotify_legacy.h"
-+#endif
- #ifdef ENABLE_DNOTIFY
- #include "gam_dnotify.h"
- #endif
-@@ -85,6 +88,9 @@ gam_show_debug(void) {
- #ifdef ENABLE_INOTIFY
- gam_inotify_debug ();
- #endif
-+#ifdef ENABLE_INOTIFY_LEGACY
-+ gam_inotify_legacy_debug ();
-+#endif
- #ifdef ENABLE_DNOTIFY
- gam_dnotify_debug ();
- #endif
-@@ -110,6 +116,12 @@ gam_init_subscriptions(void)
- return(TRUE);
- }
- #endif
-+#ifdef ENABLE_INOTIFY_LEGACY
-+ if (gam_inotify_legacy_init()) {
-+ GAM_DEBUG(DEBUG_INFO, "Using INotify Legacy as backend\n");
-+ return(TRUE);
-+ }
-+#endif
- #ifdef ENABLE_DNOTIFY
- if (gam_dnotify_init()) {
- GAM_DEBUG(DEBUG_INFO, "Using DNotify as backend\n");
-diff -urpN gamin-0.1.2/server/local_inotify_legacy.h gamin-0.1.2.az/server/local_inotify_legacy.h
---- gamin-0.1.2/server/local_inotify_legacy.h 1970-01-01 02:00:00.000000000 +0200
-+++ gamin-0.1.2.az/server/local_inotify_legacy.h 2005-07-16 08:42:16.000000000 +0200
-@@ -0,0 +1,124 @@
-+/*
-+ * Inode based directory notification for Linux
-+ *
-+ * Copyright (C) 2005 John McCutchan
-+ */
-+
-+#ifndef _LINUX_INOTIFY_LEGACY_H
-+#define _LINUX_INOTIFY_LEGACY_H
-+
-+#include <linux/types.h>
-+
-+/*
-+ * struct inotify_event - structure read from the inotify device for each event
-+ *
-+ * When you are watching a directory, you will receive the filename for events
-+ * such as IN_CREATE, IN_DELETE, IN_OPEN, IN_CLOSE, ..., relative to the wd.
-+ */
-+struct inotify_event {
-+ __s32 wd; /* watch descriptor */
-+ __u32 mask; /* watch mask */
-+ __u32 cookie; /* cookie to synchronize two events */
-+ __u32 len; /* length (including nulls) of name */
-+ char name[0]; /* stub for possible name */
-+};
-+
-+/*
-+ * struct inotify_watch_request - represents a watch request
-+ *
-+ * Pass to the inotify device via the INOTIFY_WATCH ioctl
-+ */
-+struct inotify_watch_request {
-+ int fd; /* fd of filename to watch */
-+ __u32 mask; /* event mask */
-+};
-+
-+/* the following are legal, implemented events that user-space can watch for */
-+#define IN_ACCESS 0x00000001 /* File was accessed */
-+#define IN_MODIFY 0x00000002 /* File was modified */
-+#define IN_ATTRIB 0x00000004 /* Metadata changed */
-+#define IN_CLOSE_WRITE 0x00000008 /* Writtable file was closed */
-+#define IN_CLOSE_NOWRITE 0x00000010 /* Unwrittable file closed */
-+#define IN_OPEN 0x00000020 /* File was opened */
-+#define IN_MOVED_FROM 0x00000040 /* File was moved from X */
-+#define IN_MOVED_TO 0x00000080 /* File was moved to Y */
-+#define IN_CREATE 0x00000100 /* Subfile was created */
-+#define IN_DELETE 0x00000200 /* Subfile was deleted */
-+#define IN_DELETE_SELF 0x00000400 /* Self was deleted */
-+
-+/* the following are legal events. they are sent as needed to any watch */
-+#define IN_UNMOUNT 0x00002000 /* Backing fs was unmounted */
-+#define IN_Q_OVERFLOW 0x00004000 /* Event queued overflowed */
-+#define IN_IGNORED 0x00008000 /* File was ignored */
-+
-+/* helper events */
-+#define IN_CLOSE (IN_CLOSE_WRITE | IN_CLOSE_NOWRITE) /* close */
-+#define IN_MOVE (IN_MOVED_FROM | IN_MOVED_TO) /* moves */
-+
-+/* special flags */
-+#define IN_ISDIR 0x40000000 /* event occurred against dir */
-+#define IN_ONESHOT 0x80000000 /* only send event once */
-+
-+/*
-+ * All of the events - we build the list by hand so that we can add flags in
-+ * the future and not break backward compatibility. Apps will get only the
-+ * events that they originally wanted. Be sure to add new events here!
-+ */
-+#define IN_ALL_EVENTS (IN_ACCESS | IN_MODIFY | IN_ATTRIB | IN_CLOSE_WRITE | \
-+ IN_CLOSE_NOWRITE | IN_OPEN | IN_MOVED_FROM | \
-+ IN_MOVED_TO | IN_DELETE | IN_CREATE | IN_DELETE_SELF)
-+
-+#define INOTIFY_IOCTL_MAGIC 'Q'
-+#define INOTIFY_IOCTL_MAXNR 2
-+
-+#define INOTIFY_WATCH _IOR(INOTIFY_IOCTL_MAGIC, 1, struct inotify_watch_request)
-+#define INOTIFY_IGNORE _IOR(INOTIFY_IOCTL_MAGIC, 2, int)
-+
-+#ifdef __KERNEL__
-+
-+#include <linux/dcache.h>
-+#include <linux/fs.h>
-+#include <linux/config.h>
-+
-+#ifdef CONFIG_INOTIFY
-+
-+extern void inotify_inode_queue_event(struct inode *, __u32, __u32,
-+ const char *);
-+extern void inotify_dentry_parent_queue_event(struct dentry *, __u32, __u32,
-+ const char *);
-+extern void inotify_unmount_inodes(struct list_head *);
-+extern void inotify_inode_is_dead(struct inode *);
-+extern u32 inotify_get_cookie(void);
-+
-+#else
-+
-+static inline void inotify_inode_queue_event(struct inode *inode,
-+ __u32 mask, __u32 cookie,
-+ const char *filename)
-+{
-+}
-+
-+static inline void inotify_dentry_parent_queue_event(struct dentry *dentry,
-+ __u32 mask, __u32 cookie,
-+ const char *filename)
-+{
-+}
-+
-+static inline void inotify_unmount_inodes(struct list_head *list)
-+{
-+}
-+
-+static inline void inotify_inode_is_dead(struct inode *inode)
-+{
-+}
-+
-+static inline u32 inotify_get_cookie(void)
-+{
-+ return 0;
-+}
-+
-+#endif /* CONFIG_INOTIFY */
-+
-+#endif /* __KERNEL __ */
-+
-+#endif /* _LINUX_INOTIFY_LEGACY_H */
diff --git a/app-admin/gamin/gamin-0.1.1.ebuild b/app-admin/gamin/gamin-0.1.1.ebuild
deleted file mode 100644
index ef648e86f42d..000000000000
--- a/app-admin/gamin/gamin-0.1.1.ebuild
+++ /dev/null
@@ -1,55 +0,0 @@
-# Copyright 1999-2005 Gentoo Foundation
-# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/app-admin/gamin/gamin-0.1.1.ebuild,v 1.2 2005/07/02 08:56:06 cardoe Exp $
-
-inherit eutils
-
-DESCRIPTION="Library providing the FAM File Alteration Monitor API"
-HOMEPAGE="http://www.gnome.org/~veillard/gamin/"
-SRC_URI="http://www.gnome.org/~veillard/gamin/sources/${P}.tar.gz"
-
-LICENSE="LGPL-2"
-SLOT="0"
-KEYWORDS="~x86 ~amd64 ~arm ~hppa ~ia64 ~ppc ~s390"
-IUSE="debug doc"
-
-RDEPEND="virtual/libc
- >=dev-libs/glib-2
- !app-admin/fam"
-
-DEPEND="${RDEPEND}
- dev-util/pkgconfig"
-
-PROVIDE="virtual/fam"
-
-src_unpack() {
- unpack ${A}
- cd ${S}
- epatch ${FILESDIR}/${P}-inotify-fix.patch
-}
-
-src_compile() {
- econf \
- $(use_enable kernel_linux inotify) \
- $(use_enable debug) \
- $(use_enable debug debug-api) \
- || die "econf failed"
-
- emake || die "emake failed"
-}
-
-src_install() {
- make DESTDIR="${D}" install || die
-
- dodoc AUTHORS ChangeLog README TODO NEWS doc/*txt
- use doc && dohtml doc/*
-}
-
-pkg_postinst() {
- if use kernel_linux; then
- einfo "It is strongly suggested you use Gamin with an inotify enabled"
- einfo "kernel for best performance. For this release of gamin you need"
- einfo "at least an inotify 0.23-6 patched kernel, gentoo-sources-2.6.12"
- einfo "provides this patch for example."
- fi
-}
diff --git a/app-admin/gamin/gamin-0.1.2.ebuild b/app-admin/gamin/gamin-0.1.2.ebuild
deleted file mode 100644
index a371fbe50979..000000000000
--- a/app-admin/gamin/gamin-0.1.2.ebuild
+++ /dev/null
@@ -1,70 +0,0 @@
-# Copyright 1999-2005 Gentoo Foundation
-# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/app-admin/gamin/gamin-0.1.2.ebuild,v 1.4 2005/07/16 10:11:47 flameeyes Exp $
-
-inherit eutils libtool
-
-DESCRIPTION="Library providing the FAM File Alteration Monitor API"
-HOMEPAGE="http://www.gnome.org/~veillard/gamin/"
-SRC_URI="http://www.gnome.org/~veillard/gamin/sources/${P}.tar.gz"
-
-LICENSE="LGPL-2"
-SLOT="0"
-KEYWORDS="~x86 ~amd64 ~arm ~hppa ~ia64 ~ppc ~s390"
-IUSE="debug doc"
-
-RDEPEND="virtual/libc
- >=dev-libs/glib-2
- !app-admin/fam"
-
-DEPEND="${RDEPEND}
- dev-util/pkgconfig"
-
-PROVIDE="virtual/fam"
-
-src_unpack() {
- unpack ${A}
-
- cd ${S}
- # Fixup FreeBSD support, bug #99158
- epatch ${FILESDIR}/${P}-freebsd.patch
- # Add support for legacy inotify interface
- epatch ${FILESDIR}/${P}-inotify-legacy-backend.patch
-
- # Needed by above 'legacy inotify' patch
- aclocal || die "aclocal failed"
- autoheader || die "autoheader failed"
- libtoolize --automake -c -f || die "libtoolize failed"
- autoconf || die "autoconf failed"
- automake -a -c || die "automake failed"
-
- # Do not remove
- elibtoolize
-}
-
-src_compile() {
- econf \
- $(use_enable kernel_linux inotify) \
- $(use_enable kernel_linux inotify-legacy) \
- $(use_enable debug) \
- $(use_enable debug debug-api) \
- || die "econf failed"
-
- emake || die "emake failed"
-}
-
-src_install() {
- make DESTDIR="${D}" install || die
-
- dodoc AUTHORS ChangeLog README TODO NEWS doc/*txt
- use doc && dohtml doc/*
-}
-
-pkg_postinst() {
- if use kernel_linux; then
- einfo "It is strongly suggested you use Gamin with an inotify enabled"
- einfo "kernel for best performance. For this release of gamin you need"
- einfo "at least an inotify 0.23-6 patched kernel, gentoo-sources-2.6.12"
- einfo "provides this patch for example."
- fi
-}