mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-27 14:36:16 +01:00
GUnixFileMonitor: Clean up /proc/mounts monitoring
Most suggestions from Colin Walters <walters@verbum.org>. https://bugzilla.gnome.org/show_bug.cgi?id=660511 Signed-off-by: David Zeuthen <davidz@redhat.com>
This commit is contained in:
parent
55065461bf
commit
934e0a7470
@ -154,7 +154,6 @@ struct _GUnixMountMonitor {
|
|||||||
GFileMonitor *fstab_monitor;
|
GFileMonitor *fstab_monitor;
|
||||||
GFileMonitor *mtab_monitor;
|
GFileMonitor *mtab_monitor;
|
||||||
|
|
||||||
GIOChannel *proc_mounts_channel;
|
|
||||||
GSource *proc_mounts_watch_source;
|
GSource *proc_mounts_watch_source;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1254,8 +1253,6 @@ g_unix_mount_monitor_finalize (GObject *object)
|
|||||||
g_object_unref (monitor->fstab_monitor);
|
g_object_unref (monitor->fstab_monitor);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (monitor->proc_mounts_channel != NULL)
|
|
||||||
g_io_channel_unref (monitor->proc_mounts_channel);
|
|
||||||
if (monitor->proc_mounts_watch_source != NULL)
|
if (monitor->proc_mounts_watch_source != NULL)
|
||||||
g_source_destroy (monitor->proc_mounts_watch_source);
|
g_source_destroy (monitor->proc_mounts_watch_source);
|
||||||
|
|
||||||
@ -1351,10 +1348,8 @@ proc_mounts_changed (GIOChannel *channel,
|
|||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
GUnixMountMonitor *mount_monitor = G_UNIX_MOUNT_MONITOR (user_data);
|
GUnixMountMonitor *mount_monitor = G_UNIX_MOUNT_MONITOR (user_data);
|
||||||
if (cond & ~G_IO_ERR)
|
if (cond & G_IO_ERR)
|
||||||
goto out;
|
|
||||||
g_signal_emit (mount_monitor, signals[MOUNTS_CHANGED], 0);
|
g_signal_emit (mount_monitor, signals[MOUNTS_CHANGED], 0);
|
||||||
out:
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1377,11 +1372,23 @@ g_unix_mount_monitor_init (GUnixMountMonitor *monitor)
|
|||||||
const gchar *mtab_path;
|
const gchar *mtab_path;
|
||||||
|
|
||||||
mtab_path = get_mtab_monitor_file ();
|
mtab_path = get_mtab_monitor_file ();
|
||||||
/* /proc/mounts monitoring is special - can't just use GFileMonitor */
|
/* /proc/mounts monitoring is special - can't just use GFileMonitor.
|
||||||
|
* See 'man proc' for more details.
|
||||||
|
*/
|
||||||
if (g_strcmp0 (mtab_path, "/proc/mounts") == 0)
|
if (g_strcmp0 (mtab_path, "/proc/mounts") == 0)
|
||||||
{
|
{
|
||||||
monitor->proc_mounts_channel = g_io_channel_new_file ("/proc/mounts", "r", NULL);
|
GIOChannel *proc_mounts_channel;
|
||||||
monitor->proc_mounts_watch_source = g_io_create_watch (monitor->proc_mounts_channel, G_IO_ERR);
|
GError *error = NULL;
|
||||||
|
proc_mounts_channel = g_io_channel_new_file ("/proc/mounts", "r", &error);
|
||||||
|
if (proc_mounts_channel == NULL)
|
||||||
|
{
|
||||||
|
g_warning ("Error creating IO channel for /proc/mounts: %s (%s, %d)",
|
||||||
|
error->message, g_quark_to_string (error->domain), error->code);
|
||||||
|
g_error_free (error);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
monitor->proc_mounts_watch_source = g_io_create_watch (proc_mounts_channel, G_IO_ERR);
|
||||||
g_source_set_callback (monitor->proc_mounts_watch_source,
|
g_source_set_callback (monitor->proc_mounts_watch_source,
|
||||||
(GSourceFunc) proc_mounts_changed,
|
(GSourceFunc) proc_mounts_changed,
|
||||||
monitor,
|
monitor,
|
||||||
@ -1389,10 +1396,12 @@ g_unix_mount_monitor_init (GUnixMountMonitor *monitor)
|
|||||||
g_source_attach (monitor->proc_mounts_watch_source,
|
g_source_attach (monitor->proc_mounts_watch_source,
|
||||||
g_main_context_get_thread_default ());
|
g_main_context_get_thread_default ());
|
||||||
g_source_unref (monitor->proc_mounts_watch_source);
|
g_source_unref (monitor->proc_mounts_watch_source);
|
||||||
|
g_io_channel_unref (proc_mounts_channel);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
file = g_file_new_for_path (get_mtab_monitor_file ());
|
file = g_file_new_for_path (mtab_path);
|
||||||
monitor->mtab_monitor = g_file_monitor_file (file, 0, NULL, NULL);
|
monitor->mtab_monitor = g_file_monitor_file (file, 0, NULL, NULL);
|
||||||
g_object_unref (file);
|
g_object_unref (file);
|
||||||
g_signal_connect (monitor->mtab_monitor, "changed", (GCallback)mtab_file_changed, monitor);
|
g_signal_connect (monitor->mtab_monitor, "changed", (GCallback)mtab_file_changed, monitor);
|
||||||
|
Loading…
Reference in New Issue
Block a user