diff options
author | Martin Schlemmer <azarah@gentoo.org> | 2005-07-16 08:09:15 +0000 |
---|---|---|
committer | Martin Schlemmer <azarah@gentoo.org> | 2005-07-16 08:09:15 +0000 |
commit | f00a8b6f0697916c31c9d4703b32cfc7681246bd (patch) | |
tree | d0299826a7acfd09c9144f1e368995b8e0ea3b24 /app-admin/gamin | |
parent | Add patch to fix support for custom makefiles (#86780). Update the template f... (diff) | |
download | gentoo-2-f00a8b6f0697916c31c9d4703b32cfc7681246bd.tar.gz gentoo-2-f00a8b6f0697916c31c9d4703b32cfc7681246bd.tar.bz2 gentoo-2-f00a8b6f0697916c31c9d4703b32cfc7681246bd.zip |
Update version. Add support for legacy inotify (patch from me).
(Portage version: 2.0.51.22-r1)
Diffstat (limited to 'app-admin/gamin')
-rw-r--r-- | app-admin/gamin/ChangeLog | 8 | ||||
-rw-r--r-- | app-admin/gamin/Manifest | 38 | ||||
-rw-r--r-- | app-admin/gamin/files/digest-gamin-0.1.2 | 1 | ||||
-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.2.ebuild | 68 |
5 files changed, 977 insertions, 22 deletions
diff --git a/app-admin/gamin/ChangeLog b/app-admin/gamin/ChangeLog index 2f086ec2422e..588f38f50c4d 100644 --- a/app-admin/gamin/ChangeLog +++ b/app-admin/gamin/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for app-admin/gamin # Copyright 1999-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/app-admin/gamin/ChangeLog,v 1.22 2005/07/02 08:56:06 cardoe Exp $ +# $Header: /var/cvsroot/gentoo-x86/app-admin/gamin/ChangeLog,v 1.23 2005/07/16 08:09:15 azarah Exp $ + +*gamin-0.1.2 (16 Jul 2005) + + 16 Jul 2005; Martin Schlemmer <azarah@gentoo.org> + +files/gamin-0.1.2-inotify-legacy-backend.patch, +gamin-0.1.2.ebuild: + Update version. Add support for legacy inotify (patch from me). 02 Jul 2005; Doug Goldstein <cardoe@gentoo.org> gamin-0.1.1.ebuild: some FreeBSD fix-ups diff --git a/app-admin/gamin/Manifest b/app-admin/gamin/Manifest index 7f42ca07d899..d75487c4f912 100644 --- a/app-admin/gamin/Manifest +++ b/app-admin/gamin/Manifest @@ -1,30 +1,26 @@ ------BEGIN PGP SIGNED MESSAGE----- -Hash: SHA1 - -MD5 aded813c1b4b7658676a522c12a49ce6 ChangeLog 4312 -MD5 39ade60322eb86b40eca5ba38fd6d522 gamin-0.0.15.ebuild 842 +MD5 59d28e6a7eced2cd85355b76c6ae02b4 gamin-0.0.26.ebuild 1186 MD5 2695c38fbf4b4e11fe5d9c4d6f080ffc gamin-0.0.18.ebuild 889 +MD5 03f3bc849895689c9635a6a7e8c11d0b gamin-0.1.2.ebuild 1345 MD5 e14b51caa6ba40b1982f36284c19f75b gamin-0.0.19.ebuild 833 -MD5 1a12b6356c49807d6a034d775c96575f gamin-0.0.20.ebuild 828 MD5 d56aae268087693c5b5fe3fc58cdae4c gamin-0.0.25.ebuild 1185 MD5 0cdad230fe4f3ab61550ef8079ddeb1f gamin-0.0.26-r6.ebuild 1258 -MD5 59d28e6a7eced2cd85355b76c6ae02b4 gamin-0.0.26.ebuild 1186 -MD5 875135e8740bafa4dab79ee592cf9744 metadata.xml 279 +MD5 aded813c1b4b7658676a522c12a49ce6 ChangeLog 4312 +MD5 3bc59692bad17711047f1c46a73dc15f gamin-0.1.1.1.ebuild 1229 MD5 03f3bc849895689c9635a6a7e8c11d0b gamin-0.1.1.ebuild 1345 +MD5 1a12b6356c49807d6a034d775c96575f gamin-0.0.20.ebuild 828 +MD5 875135e8740bafa4dab79ee592cf9744 metadata.xml 279 +MD5 39ade60322eb86b40eca5ba38fd6d522 gamin-0.0.15.ebuild 842 +MD5 3bc59692bad17711047f1c46a73dc15f gamin-0.1.1.2.ebuild 1229 +MD5 fd8dba98fd1b79aed73e3b6f17e0a779 files/digest-gamin-0.1.1 63 +MD5 8ae001c8ed4cb897aef23abe51c53dbf files/digest-gamin-0.1.1.2 65 +MD5 50691da4c01bbd32e1397b8873180986 files/gamin-0.1.1-inotify-fix.patch 14533 +MD5 a6ae9d25c124ec87523b00e860cc0d2f files/digest-gamin-0.0.25 64 +MD5 caf15e7329c9675dff66e7f65b424e79 files/digest-gamin-0.0.26-r6 64 MD5 c576a2ec43ce151b5bc78b77e0f58c9a files/digest-gamin-0.0.15 64 +MD5 caf15e7329c9675dff66e7f65b424e79 files/digest-gamin-0.0.26 64 MD5 b183176dcfe9a0ad1609767f11cafc12 files/digest-gamin-0.0.18 64 -MD5 35d7d4d3208d674f62e4f2d7ef7d383f files/digest-gamin-0.0.19 64 MD5 04ae13b77ce72f4c93d0460b1bbcfd57 files/digest-gamin-0.0.20 64 -MD5 a6ae9d25c124ec87523b00e860cc0d2f files/digest-gamin-0.0.25 64 -MD5 caf15e7329c9675dff66e7f65b424e79 files/digest-gamin-0.0.26 64 -MD5 caf15e7329c9675dff66e7f65b424e79 files/digest-gamin-0.0.26-r6 64 +MD5 35d7d4d3208d674f62e4f2d7ef7d383f files/digest-gamin-0.0.19 64 +MD5 2ab0167c306465e140ebfe2d8151fced files/digest-gamin-0.1.2 63 MD5 315c32e4751bc7d3bcfd88e03841a168 files/gamin-0.0.26-inotify_use_fd.patch 2759 -MD5 fd8dba98fd1b79aed73e3b6f17e0a779 files/digest-gamin-0.1.1 63 -MD5 50691da4c01bbd32e1397b8873180986 files/gamin-0.1.1-inotify-fix.patch 14533 ------BEGIN PGP SIGNATURE----- -Version: GnuPG v1.4.1 (GNU/Linux) - -iD8DBQFCxla7BtvusYtCZMsRAmbSAJ9eXIhd63DSF+uJsRd2FSqrvgp66ACeI3XW -25WKjImVYeJTQ8+JVlyfSS4= -=HYix ------END PGP SIGNATURE----- +MD5 b78628c91ff53a24a33390f3c5fc3714 files/digest-gamin-0.1.1.1 65 diff --git a/app-admin/gamin/files/digest-gamin-0.1.2 b/app-admin/gamin/files/digest-gamin-0.1.2 new file mode 100644 index 000000000000..a079a2f4c1a1 --- /dev/null +++ b/app-admin/gamin/files/digest-gamin-0.1.2 @@ -0,0 +1 @@ +MD5 cb43e73d43e2c5d428229dea0288d66d gamin-0.1.2.tar.gz 513784 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 new file mode 100644 index 000000000000..b7a735d38341 --- /dev/null +++ b/app-admin/gamin/files/gamin-0.1.2-inotify-legacy-backend.patch @@ -0,0 +1,884 @@ +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.2.ebuild b/app-admin/gamin/gamin-0.1.2.ebuild new file mode 100644 index 000000000000..e0bb7d16c2be --- /dev/null +++ b/app-admin/gamin/gamin-0.1.2.ebuild @@ -0,0 +1,68 @@ +# 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.1 2005/07/16 08:09:15 azarah 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} + # Add support for legacy inotify interface + epatch ${FILESDIR}/${P}-inotify-legacy-backend.patch + + # Needed by above 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 +} |