diff options
author | Martin Schlemmer <azarah@gentoo.org> | 2005-08-20 16:05:30 +0000 |
---|---|---|
committer | Martin Schlemmer <azarah@gentoo.org> | 2005-08-20 16:05:30 +0000 |
commit | 3521cc618bc6f48d2e638e4f0fa459611a8aa157 (patch) | |
tree | 80605ac3465af12b6982804a6244a81c10e14e13 /app-admin | |
parent | Update version. (diff) | |
download | historical-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/Manifest | 13 | ||||
-rw-r--r-- | app-admin/gamin/files/digest-gamin-0.1.1 | 1 | ||||
-rw-r--r-- | app-admin/gamin/files/digest-gamin-0.1.2 | 1 | ||||
-rw-r--r-- | app-admin/gamin/files/gamin-0.1.1-inotify-fix.patch | 482 | ||||
-rw-r--r-- | app-admin/gamin/files/gamin-0.1.2-freebsd.patch | 124 | ||||
-rw-r--r-- | app-admin/gamin/files/gamin-0.1.2-inotify-legacy-backend.patch | 884 | ||||
-rw-r--r-- | app-admin/gamin/gamin-0.1.1.ebuild | 55 | ||||
-rw-r--r-- | app-admin/gamin/gamin-0.1.2.ebuild | 70 |
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 -} |