Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/* GIO - GLib Input, Output and Streaming Library
|
|
|
|
|
*
|
|
|
|
|
* Copyright (C) 2006-2007 Red Hat, Inc.
|
|
|
|
|
*
|
2022-05-18 10:12:45 +02:00
|
|
|
|
* SPDX-License-Identifier: LGPL-2.1-or-later
|
|
|
|
|
*
|
2007-11-26 17:13:05 +01:00
|
|
|
|
* 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
|
2017-05-27 18:21:30 +02:00
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
|
|
|
|
* 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
|
2014-01-23 12:58:29 +01:00
|
|
|
|
* Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
|
|
|
|
* Author: Alexander Larsson <alexl@redhat.com>
|
|
|
|
|
*/
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* Prologue {{{1 */
|
|
|
|
|
|
2008-06-22 17:10:51 +02:00
|
|
|
|
#include "config.h"
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
#include <sys/stat.h>
|
|
|
|
|
#include <sys/wait.h>
|
|
|
|
|
#ifndef HAVE_SYSCTLBYNAME
|
|
|
|
|
#ifdef HAVE_SYS_PARAM_H
|
|
|
|
|
#include <sys/param.h>
|
|
|
|
|
#endif
|
|
|
|
|
#endif
|
2013-12-22 17:33:07 +01:00
|
|
|
|
#ifdef HAVE_POLL
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#include <poll.h>
|
|
|
|
|
#endif
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <unistd.h>
|
|
|
|
|
#include <sys/time.h>
|
|
|
|
|
#include <errno.h>
|
|
|
|
|
#include <string.h>
|
|
|
|
|
#include <signal.h>
|
2008-04-29 00:38:49 +02:00
|
|
|
|
#include <gstdio.h>
|
2009-02-25 17:37:35 +01:00
|
|
|
|
#include <dirent.h>
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2024-04-02 13:43:00 +02:00
|
|
|
|
#if defined(__ANDROID__) && (__ANDROID_API__ < 26)
|
2023-05-20 12:39:09 +02:00
|
|
|
|
#include <mntent.h>
|
|
|
|
|
/* the shared object of recent bionic libc's have hasmntopt symbol, but
|
|
|
|
|
some a possible common build environment for android, termux ends
|
2024-04-02 13:48:39 +02:00
|
|
|
|
up with insufficient __ANDROID_API__ value for building.
|
2023-05-20 12:39:09 +02:00
|
|
|
|
*/
|
|
|
|
|
extern char* hasmntopt(const struct mntent* mnt, const char* opt);
|
|
|
|
|
#endif
|
|
|
|
|
|
2011-07-18 18:58:01 +02:00
|
|
|
|
#if HAVE_SYS_STATFS_H
|
|
|
|
|
#include <sys/statfs.h>
|
|
|
|
|
#endif
|
|
|
|
|
#if HAVE_SYS_STATVFS_H
|
|
|
|
|
#include <sys/statvfs.h>
|
|
|
|
|
#endif
|
|
|
|
|
#if HAVE_SYS_VFS_H
|
|
|
|
|
#include <sys/vfs.h>
|
|
|
|
|
#elif HAVE_SYS_MOUNT_H
|
|
|
|
|
#if HAVE_SYS_PARAM_H
|
|
|
|
|
#include <sys/param.h>
|
|
|
|
|
#endif
|
|
|
|
|
#include <sys/mount.h>
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifndef O_BINARY
|
|
|
|
|
#define O_BINARY 0
|
|
|
|
|
#endif
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#include "gunixmounts.h"
|
|
|
|
|
#include "gfile.h"
|
|
|
|
|
#include "gfilemonitor.h"
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
#include "glibintl.h"
|
2020-06-11 17:31:39 +02:00
|
|
|
|
#include "glocalfile.h"
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
#include "gthemedicon.h"
|
2015-01-08 07:35:33 +01:00
|
|
|
|
#include "gcontextspecificgroup.h"
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2007-11-28 13:39:07 +01:00
|
|
|
|
|
2011-09-01 11:10:38 +02:00
|
|
|
|
#ifdef HAVE_MNTENT_H
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
static const char *_resolve_dev_root (void);
|
2011-09-01 11:10:38 +02:00
|
|
|
|
#endif
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
|
2014-08-18 14:08:41 +02:00
|
|
|
|
/**
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
* GUnixMountType:
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* @G_UNIX_MOUNT_TYPE_UNKNOWN: Unknown Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_FLOPPY: Floppy disk Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_CDROM: CDROM Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_NFS: Network File System (NFS) Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_ZIP: ZIP Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_JAZ: JAZZ Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_MEMSTICK: Memory Stick Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_CF: Compact Flash Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_SM: Smart Media Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_SDMMC: SD/MMC Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_IPOD: iPod Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_CAMERA: Digital camera Unix mount type.
|
|
|
|
|
* @G_UNIX_MOUNT_TYPE_HD: Hard drive Unix mount type.
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Types of Unix mounts.
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
**/
|
|
|
|
|
typedef enum {
|
|
|
|
|
G_UNIX_MOUNT_TYPE_UNKNOWN,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_FLOPPY,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_CDROM,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_NFS,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_ZIP,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_JAZ,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_MEMSTICK,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_CF,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_SM,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_SDMMC,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_IPOD,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_CAMERA,
|
|
|
|
|
G_UNIX_MOUNT_TYPE_HD
|
|
|
|
|
} GUnixMountType;
|
|
|
|
|
|
|
|
|
|
struct _GUnixMountEntry {
|
2007-11-26 17:13:05 +01:00
|
|
|
|
char *mount_path;
|
|
|
|
|
char *device_path;
|
2018-04-26 10:37:33 +02:00
|
|
|
|
char *root_path;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
char *filesystem_type;
|
2018-04-26 10:36:36 +02:00
|
|
|
|
char *options;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
gboolean is_read_only;
|
|
|
|
|
gboolean is_system_internal;
|
|
|
|
|
};
|
|
|
|
|
|
2024-10-18 11:31:12 +02:00
|
|
|
|
G_DEFINE_BOXED_TYPE (GUnixMountEntry, g_unix_mount_entry, g_unix_mount_entry_copy, g_unix_mount_entry_free)
|
2017-03-23 12:46:56 +01:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
struct _GUnixMountPoint {
|
|
|
|
|
char *mount_path;
|
|
|
|
|
char *device_path;
|
|
|
|
|
char *filesystem_type;
|
2011-09-30 05:46:28 +02:00
|
|
|
|
char *options;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
gboolean is_read_only;
|
|
|
|
|
gboolean is_user_mountable;
|
|
|
|
|
gboolean is_loopback;
|
|
|
|
|
};
|
|
|
|
|
|
2017-03-23 12:46:56 +01:00
|
|
|
|
G_DEFINE_BOXED_TYPE (GUnixMountPoint, g_unix_mount_point,
|
|
|
|
|
g_unix_mount_point_copy, g_unix_mount_point_free)
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
static GList *_g_get_unix_mounts (void);
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountEntry **_g_unix_mounts_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_entries_out);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
static GList *_g_get_unix_mount_points (void);
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountPoint **_g_unix_mount_points_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_points_out);
|
2017-09-08 18:42:14 +02:00
|
|
|
|
static gboolean proc_mounts_watch_is_running (void);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2020-02-10 16:00:42 +01:00
|
|
|
|
G_LOCK_DEFINE_STATIC (proc_mounts_source);
|
|
|
|
|
|
|
|
|
|
/* Protected by proc_mounts_source lock */
|
2014-08-18 22:48:28 +02:00
|
|
|
|
static guint64 mount_poller_time = 0;
|
2024-04-19 09:54:50 +02:00
|
|
|
|
static GSource *proc_mounts_watch_source = NULL;
|
2014-08-18 22:48:28 +02:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#ifdef HAVE_SYS_MNTTAB_H
|
|
|
|
|
#define MNTOPT_RO "ro"
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_MNTENT_H
|
|
|
|
|
#include <mntent.h>
|
2016-07-19 12:51:55 +02:00
|
|
|
|
#ifdef HAVE_LIBMOUNT
|
2018-02-12 13:13:01 +01:00
|
|
|
|
#include <libmount.h>
|
2016-07-19 12:51:55 +02:00
|
|
|
|
#endif
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#elif defined (HAVE_SYS_MNTTAB_H)
|
|
|
|
|
#include <sys/mnttab.h>
|
2019-10-04 22:23:25 +02:00
|
|
|
|
#if defined(__sun) && !defined(mnt_opts)
|
2019-10-04 21:55:14 +02:00
|
|
|
|
#define mnt_opts mnt_mntopts
|
|
|
|
|
#endif
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_SYS_VFSTAB_H
|
|
|
|
|
#include <sys/vfstab.h>
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if defined(HAVE_SYS_MNTCTL_H) && defined(HAVE_SYS_VMOUNT_H) && defined(HAVE_SYS_VFS_H)
|
|
|
|
|
#include <sys/mntctl.h>
|
|
|
|
|
#include <sys/vfs.h>
|
|
|
|
|
#include <sys/vmount.h>
|
|
|
|
|
#include <fshelp.h>
|
|
|
|
|
#endif
|
|
|
|
|
|
2011-09-01 11:10:38 +02:00
|
|
|
|
#if (defined(HAVE_GETVFSSTAT) || defined(HAVE_GETFSSTAT)) && defined(HAVE_FSTAB_H) && defined(HAVE_SYS_MOUNT_H)
|
2014-08-18 22:48:28 +02:00
|
|
|
|
#include <sys/param.h>
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#include <sys/ucred.h>
|
|
|
|
|
#include <sys/mount.h>
|
|
|
|
|
#include <fstab.h>
|
|
|
|
|
#ifdef HAVE_SYS_SYSCTL_H
|
|
|
|
|
#include <sys/sysctl.h>
|
|
|
|
|
#endif
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifndef HAVE_SETMNTENT
|
|
|
|
|
#define setmntent(f,m) fopen(f,m)
|
|
|
|
|
#endif
|
|
|
|
|
#ifndef HAVE_ENDMNTENT
|
|
|
|
|
#define endmntent(f) fclose(f)
|
|
|
|
|
#endif
|
|
|
|
|
|
2024-01-22 15:29:37 +01:00
|
|
|
|
#ifdef HAVE_LIBMOUNT
|
|
|
|
|
/* Protected by proc_mounts_source lock */
|
|
|
|
|
static struct libmnt_monitor *proc_mounts_monitor = NULL;
|
|
|
|
|
#endif
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static guint64 get_mounts_timestamp (void);
|
|
|
|
|
static guint64 get_mount_points_timestamp (void);
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
static gboolean
|
|
|
|
|
is_in (const char *value, const char *set[])
|
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
for (i = 0; set[i] != NULL; i++)
|
|
|
|
|
{
|
|
|
|
|
if (strcmp (set[i], value) == 0)
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
/* Marked as unused because these are only used on some platform variants, but
|
|
|
|
|
* working out the #if sequence for that would be too much for my little brain. */
|
|
|
|
|
static GList *unix_mount_entry_array_free_to_list (GUnixMountEntry **entries,
|
|
|
|
|
size_t n_entries) G_GNUC_UNUSED;
|
|
|
|
|
static GList *unix_mount_point_array_free_to_list (GUnixMountPoint **points,
|
|
|
|
|
size_t n_points) G_GNUC_UNUSED;
|
|
|
|
|
|
|
|
|
|
/* Helper to convert to a list for the old API.
|
|
|
|
|
* Steals ownership of the @entries array. */
|
|
|
|
|
static GList *
|
|
|
|
|
unix_mount_entry_array_free_to_list (GUnixMountEntry **entries,
|
|
|
|
|
size_t n_entries)
|
|
|
|
|
{
|
|
|
|
|
GList *l = NULL;
|
|
|
|
|
|
|
|
|
|
for (size_t i = 0; i < n_entries; i++)
|
|
|
|
|
l = g_list_prepend (l, g_steal_pointer (&entries[i]));
|
|
|
|
|
|
|
|
|
|
g_free (entries);
|
|
|
|
|
|
|
|
|
|
return g_list_reverse (l);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Helper to convert to a list for the old API.
|
|
|
|
|
* Steals ownership of the @entries array. */
|
|
|
|
|
static GList *
|
|
|
|
|
unix_mount_point_array_free_to_list (GUnixMountPoint **points,
|
|
|
|
|
size_t n_points)
|
|
|
|
|
{
|
|
|
|
|
GList *l = NULL;
|
|
|
|
|
|
|
|
|
|
for (size_t i = 0; i < n_points; i++)
|
|
|
|
|
l = g_list_prepend (l, g_steal_pointer (&points[i]));
|
|
|
|
|
|
|
|
|
|
g_free (points);
|
|
|
|
|
|
|
|
|
|
return g_list_reverse (l);
|
|
|
|
|
}
|
|
|
|
|
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_is_mount_path_system_internal:
|
2016-06-04 17:53:42 +02:00
|
|
|
|
* @mount_path: (type filename): a mount path, e.g. `/media/disk` or `/usr`
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
*
|
|
|
|
|
* Determines if @mount_path is considered an implementation of the
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* OS.
|
|
|
|
|
*
|
|
|
|
|
* This is primarily used for hiding mountable and mounted volumes
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
* that only are used in the OS and has little to no relevance to the
|
|
|
|
|
* casual user.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if @mount_path is considered an implementation detail
|
|
|
|
|
* of the OS; false otherwise
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
**/
|
|
|
|
|
gboolean
|
|
|
|
|
g_unix_is_mount_path_system_internal (const char *mount_path)
|
|
|
|
|
{
|
|
|
|
|
const char *ignore_mountpoints[] = {
|
2015-06-05 01:25:20 +02:00
|
|
|
|
/* Includes all FHS 2.3 toplevel dirs and other specialized
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
* directories that we want to hide from the user.
|
|
|
|
|
*/
|
|
|
|
|
"/", /* we already have "Filesystem root" in Nautilus */
|
|
|
|
|
"/bin",
|
|
|
|
|
"/boot",
|
2014-01-21 17:25:35 +01:00
|
|
|
|
"/compat/linux/proc",
|
|
|
|
|
"/compat/linux/sys",
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
"/dev",
|
|
|
|
|
"/etc",
|
|
|
|
|
"/home",
|
|
|
|
|
"/lib",
|
|
|
|
|
"/lib64",
|
2014-01-21 17:25:35 +01:00
|
|
|
|
"/libexec",
|
2011-07-20 10:52:07 +02:00
|
|
|
|
"/live/cow",
|
|
|
|
|
"/live/image",
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
"/media",
|
|
|
|
|
"/mnt",
|
|
|
|
|
"/opt",
|
2014-01-21 17:25:35 +01:00
|
|
|
|
"/rescue",
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
"/root",
|
|
|
|
|
"/sbin",
|
|
|
|
|
"/srv",
|
|
|
|
|
"/tmp",
|
|
|
|
|
"/usr",
|
2014-01-21 17:25:35 +01:00
|
|
|
|
"/usr/X11R6",
|
2008-01-03 11:29:29 +01:00
|
|
|
|
"/usr/local",
|
2014-01-21 17:25:35 +01:00
|
|
|
|
"/usr/obj",
|
|
|
|
|
"/usr/ports",
|
|
|
|
|
"/usr/src",
|
|
|
|
|
"/usr/xobj",
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
"/var",
|
2011-07-20 10:52:07 +02:00
|
|
|
|
"/var/crash",
|
|
|
|
|
"/var/local",
|
2022-12-02 22:45:44 +01:00
|
|
|
|
GLIB_LOCALSTATEDIR,
|
2011-07-20 10:52:07 +02:00
|
|
|
|
"/var/log",
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
"/var/log/audit", /* https://bugzilla.redhat.com/show_bug.cgi?id=333041 */
|
2011-07-20 10:52:07 +02:00
|
|
|
|
"/var/mail",
|
|
|
|
|
"/var/run",
|
2022-12-02 22:45:44 +01:00
|
|
|
|
GLIB_RUNSTATEDIR,
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
"/var/tmp", /* https://bugzilla.redhat.com/show_bug.cgi?id=335241 */
|
|
|
|
|
"/proc",
|
|
|
|
|
"/sbin",
|
|
|
|
|
"/net",
|
2010-07-08 21:18:05 +02:00
|
|
|
|
"/sys",
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
NULL
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
if (is_in (mount_path, ignore_mountpoints))
|
|
|
|
|
return TRUE;
|
|
|
|
|
|
2010-07-08 21:18:05 +02:00
|
|
|
|
if (g_str_has_prefix (mount_path, "/dev/") ||
|
|
|
|
|
g_str_has_prefix (mount_path, "/proc/") ||
|
|
|
|
|
g_str_has_prefix (mount_path, "/sys/"))
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
return TRUE;
|
|
|
|
|
|
2010-07-08 21:18:05 +02:00
|
|
|
|
if (g_str_has_suffix (mount_path, "/.gvfs"))
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
2017-10-25 16:03:17 +02:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_is_system_fs_type:
|
|
|
|
|
* @fs_type: a file system type, e.g. `procfs` or `tmpfs`
|
|
|
|
|
*
|
|
|
|
|
* Determines if @fs_type is considered a type of file system which is only
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* used in implementation of the OS.
|
|
|
|
|
*
|
|
|
|
|
* This is primarily used for hiding mounted volumes that are intended as APIs
|
|
|
|
|
* for programs to read, and system administrators at a shell; rather than
|
|
|
|
|
* something that should, for example, appear in a GUI. For example, the Linux
|
|
|
|
|
* `/proc` filesystem.
|
2017-10-25 16:03:17 +02:00
|
|
|
|
*
|
|
|
|
|
* The list of file system types considered ‘system’ ones may change over time.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if @fs_type is considered an implementation detail of the OS;
|
|
|
|
|
* false otherwise
|
2017-10-25 16:03:17 +02:00
|
|
|
|
* Since: 2.56
|
|
|
|
|
*/
|
|
|
|
|
gboolean
|
|
|
|
|
g_unix_is_system_fs_type (const char *fs_type)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
const char *ignore_fs[] = {
|
2017-10-12 15:55:30 +02:00
|
|
|
|
"adfs",
|
|
|
|
|
"afs",
|
2007-11-26 17:13:05 +01:00
|
|
|
|
"auto",
|
|
|
|
|
"autofs",
|
2017-10-12 15:55:30 +02:00
|
|
|
|
"autofs4",
|
|
|
|
|
"cgroup",
|
|
|
|
|
"configfs",
|
|
|
|
|
"cxfs",
|
|
|
|
|
"debugfs",
|
2007-11-26 17:13:05 +01:00
|
|
|
|
"devfs",
|
|
|
|
|
"devpts",
|
2017-10-12 15:55:30 +02:00
|
|
|
|
"devtmpfs",
|
2008-12-08 06:47:26 +01:00
|
|
|
|
"ecryptfs",
|
2014-01-21 17:25:35 +01:00
|
|
|
|
"fdescfs",
|
2017-10-12 15:55:30 +02:00
|
|
|
|
"fusectl",
|
|
|
|
|
"gfs",
|
|
|
|
|
"gfs2",
|
|
|
|
|
"gpfs",
|
|
|
|
|
"hugetlbfs",
|
2007-11-26 17:13:05 +01:00
|
|
|
|
"kernfs",
|
|
|
|
|
"linprocfs",
|
2017-10-12 15:55:30 +02:00
|
|
|
|
"linsysfs",
|
|
|
|
|
"lustre",
|
|
|
|
|
"lustre_lite",
|
2014-01-21 17:25:35 +01:00
|
|
|
|
"mfs",
|
2017-10-12 15:55:30 +02:00
|
|
|
|
"mqueue",
|
|
|
|
|
"ncpfs",
|
|
|
|
|
"nfsd",
|
2014-01-21 17:25:35 +01:00
|
|
|
|
"nullfs",
|
2017-10-12 15:55:30 +02:00
|
|
|
|
"ocfs2",
|
|
|
|
|
"overlay",
|
2007-11-26 17:13:05 +01:00
|
|
|
|
"proc",
|
|
|
|
|
"procfs",
|
2017-10-12 15:55:30 +02:00
|
|
|
|
"pstore",
|
2007-11-26 17:13:05 +01:00
|
|
|
|
"ptyfs",
|
|
|
|
|
"rootfs",
|
2017-10-12 15:55:30 +02:00
|
|
|
|
"rpc_pipefs",
|
|
|
|
|
"securityfs",
|
2007-11-26 17:13:05 +01:00
|
|
|
|
"selinuxfs",
|
|
|
|
|
"sysfs",
|
|
|
|
|
"tmpfs",
|
|
|
|
|
"usbfs",
|
|
|
|
|
NULL
|
|
|
|
|
};
|
2017-10-25 16:03:17 +02:00
|
|
|
|
|
|
|
|
|
g_return_val_if_fail (fs_type != NULL && *fs_type != '\0', FALSE);
|
|
|
|
|
|
|
|
|
|
return is_in (fs_type, ignore_fs);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_is_system_device_path:
|
2017-11-07 14:38:58 +01:00
|
|
|
|
* @device_path: a device path, e.g. `/dev/loop0` or `nfsd`
|
2017-10-25 16:03:17 +02:00
|
|
|
|
*
|
|
|
|
|
* Determines if @device_path is considered a block device path which is only
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* used in implementation of the OS.
|
|
|
|
|
*
|
|
|
|
|
* This is primarily used for hiding mounted volumes that are intended as APIs
|
|
|
|
|
* for programs to read, and system administrators at a shell; rather than
|
|
|
|
|
* something that should, for example, appear in a GUI. For example, the Linux
|
|
|
|
|
* `/proc` filesystem.
|
2017-10-25 16:03:17 +02:00
|
|
|
|
*
|
|
|
|
|
* The list of device paths considered ‘system’ ones may change over time.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if @device_path is considered an implementation detail of
|
|
|
|
|
* the OS; false otherwise
|
2017-10-25 16:03:17 +02:00
|
|
|
|
* Since: 2.56
|
|
|
|
|
*/
|
|
|
|
|
gboolean
|
|
|
|
|
g_unix_is_system_device_path (const char *device_path)
|
|
|
|
|
{
|
2007-11-26 17:13:05 +01:00
|
|
|
|
const char *ignore_devices[] = {
|
|
|
|
|
"none",
|
|
|
|
|
"sunrpc",
|
|
|
|
|
"devpts",
|
|
|
|
|
"nfsd",
|
|
|
|
|
"/dev/loop",
|
|
|
|
|
"/dev/vn",
|
|
|
|
|
NULL
|
|
|
|
|
};
|
2017-10-25 16:03:17 +02:00
|
|
|
|
|
|
|
|
|
g_return_val_if_fail (device_path != NULL && *device_path != '\0', FALSE);
|
|
|
|
|
|
|
|
|
|
return is_in (device_path, ignore_devices);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static gboolean
|
|
|
|
|
guess_system_internal (const char *mountpoint,
|
2018-04-26 16:22:36 +02:00
|
|
|
|
const char *fs,
|
|
|
|
|
const char *device,
|
|
|
|
|
const char *root)
|
2017-10-25 16:03:17 +02:00
|
|
|
|
{
|
|
|
|
|
if (g_unix_is_system_fs_type (fs))
|
2007-11-26 17:13:05 +01:00
|
|
|
|
return TRUE;
|
|
|
|
|
|
2017-10-25 16:03:17 +02:00
|
|
|
|
if (g_unix_is_system_device_path (device))
|
2007-11-26 17:13:05 +01:00
|
|
|
|
return TRUE;
|
|
|
|
|
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
if (g_unix_is_mount_path_system_internal (mountpoint))
|
2007-11-26 17:13:05 +01:00
|
|
|
|
return TRUE;
|
2018-04-26 16:22:36 +02:00
|
|
|
|
|
|
|
|
|
/* It is not possible to reliably detect mounts which were created by bind
|
|
|
|
|
* operation. mntent-based _g_get_unix_mounts() implementation blindly skips
|
|
|
|
|
* mounts with a device path that is repeated (e.g. mounts created by bind
|
|
|
|
|
* operation, btrfs subvolumes). This usually chooses the most important
|
|
|
|
|
* mounts (i.e. which points to the root of filesystem), but it doesn't work
|
|
|
|
|
* in all cases and also it is not ideal that those mounts are completely
|
|
|
|
|
* ignored (e.g. x-gvfs-show doesn't work for them, trash backend can't handle
|
|
|
|
|
* files on btrfs subvolumes). libmount-based _g_get_unix_mounts()
|
|
|
|
|
* implementation provides a root path. So there is no need to completely
|
|
|
|
|
* ignore those mounts, because e.g. our volume monitors can use the root path
|
|
|
|
|
* to not mengle those mounts with the "regular" mounts (i.e. which points to
|
|
|
|
|
* the root). But because those mounts usually just duplicate other mounts and
|
|
|
|
|
* are completely ignored with mntend-based implementation, let's mark them as
|
2020-06-12 15:02:30 +02:00
|
|
|
|
* system internal. Given the different approaches it doesn't mean that all
|
2018-04-26 16:22:36 +02:00
|
|
|
|
* mounts which were ignored will be system internal now, but this should work
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* in most cases. For more info, see g_unix_mount_entry_get_root_path()
|
|
|
|
|
* annotation, comment in mntent-based _g_get_unix_mounts() implementation and
|
|
|
|
|
* the https://gitlab.gnome.org/GNOME/glib/issues/1271 issue.
|
2018-04-26 16:22:36 +02:00
|
|
|
|
*/
|
|
|
|
|
if (root != NULL && g_strcmp0 (root, "/") != 0)
|
|
|
|
|
return TRUE;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* GUnixMounts (ie: mtab) implementations {{{1 */
|
|
|
|
|
|
2016-07-19 13:04:27 +02:00
|
|
|
|
static GUnixMountEntry *
|
|
|
|
|
create_unix_mount_entry (const char *device_path,
|
|
|
|
|
const char *mount_path,
|
2018-04-26 10:37:33 +02:00
|
|
|
|
const char *root_path,
|
2016-07-19 13:04:27 +02:00
|
|
|
|
const char *filesystem_type,
|
2018-04-26 10:36:36 +02:00
|
|
|
|
const char *options,
|
2016-07-19 13:04:27 +02:00
|
|
|
|
gboolean is_read_only)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountEntry *mount_entry = NULL;
|
|
|
|
|
|
|
|
|
|
mount_entry = g_new0 (GUnixMountEntry, 1);
|
|
|
|
|
mount_entry->device_path = g_strdup (device_path);
|
|
|
|
|
mount_entry->mount_path = g_strdup (mount_path);
|
2018-04-26 10:37:33 +02:00
|
|
|
|
mount_entry->root_path = g_strdup (root_path);
|
2016-07-19 13:04:27 +02:00
|
|
|
|
mount_entry->filesystem_type = g_strdup (filesystem_type);
|
2018-04-26 10:36:36 +02:00
|
|
|
|
mount_entry->options = g_strdup (options);
|
2016-07-19 13:04:27 +02:00
|
|
|
|
mount_entry->is_read_only = is_read_only;
|
|
|
|
|
|
|
|
|
|
mount_entry->is_system_internal =
|
|
|
|
|
guess_system_internal (mount_entry->mount_path,
|
|
|
|
|
mount_entry->filesystem_type,
|
2018-04-26 16:22:36 +02:00
|
|
|
|
mount_entry->device_path,
|
|
|
|
|
mount_entry->root_path);
|
|
|
|
|
|
2016-07-19 13:04:27 +02:00
|
|
|
|
return mount_entry;
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-19 13:05:02 +02:00
|
|
|
|
static GUnixMountPoint *
|
|
|
|
|
create_unix_mount_point (const char *device_path,
|
|
|
|
|
const char *mount_path,
|
|
|
|
|
const char *filesystem_type,
|
|
|
|
|
const char *options,
|
|
|
|
|
gboolean is_read_only,
|
|
|
|
|
gboolean is_user_mountable,
|
|
|
|
|
gboolean is_loopback)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountPoint *mount_point = NULL;
|
|
|
|
|
|
|
|
|
|
mount_point = g_new0 (GUnixMountPoint, 1);
|
|
|
|
|
mount_point->device_path = g_strdup (device_path);
|
|
|
|
|
mount_point->mount_path = g_strdup (mount_path);
|
|
|
|
|
mount_point->filesystem_type = g_strdup (filesystem_type);
|
|
|
|
|
mount_point->options = g_strdup (options);
|
|
|
|
|
mount_point->is_read_only = is_read_only;
|
|
|
|
|
mount_point->is_user_mountable = is_user_mountable;
|
|
|
|
|
mount_point->is_loopback = is_loopback;
|
|
|
|
|
|
|
|
|
|
return mount_point;
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* mntent.h (Linux, GNU, NSS) {{{2 */
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#ifdef HAVE_MNTENT_H
|
|
|
|
|
|
2016-07-19 13:04:27 +02:00
|
|
|
|
#ifdef HAVE_LIBMOUNT
|
|
|
|
|
|
2016-05-20 17:59:02 +02:00
|
|
|
|
/* For documentation on /proc/self/mountinfo see
|
|
|
|
|
* http://www.kernel.org/doc/Documentation/filesystems/proc.txt
|
|
|
|
|
*/
|
|
|
|
|
#define PROC_MOUNTINFO_PATH "/proc/self/mountinfo"
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountEntry **
|
|
|
|
|
_g_unix_mounts_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_entries_out)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
2016-07-19 13:04:27 +02:00
|
|
|
|
struct libmnt_table *table = NULL;
|
|
|
|
|
struct libmnt_iter* iter = NULL;
|
|
|
|
|
struct libmnt_fs *fs = NULL;
|
|
|
|
|
GUnixMountEntry *mount_entry = NULL;
|
2024-07-20 14:53:57 +02:00
|
|
|
|
GPtrArray *return_array = NULL;
|
|
|
|
|
|
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = get_mounts_timestamp ();
|
2016-07-19 13:04:27 +02:00
|
|
|
|
|
2024-10-18 11:31:12 +02:00
|
|
|
|
return_array = g_ptr_array_new_null_terminated (0, (GDestroyNotify) g_unix_mount_entry_free, TRUE);
|
2017-05-05 12:33:58 +02:00
|
|
|
|
table = mnt_new_table ();
|
2024-07-20 14:53:57 +02:00
|
|
|
|
if (mnt_table_parse_mtab (table, table_path) < 0)
|
2016-07-27 21:50:54 +02:00
|
|
|
|
goto out;
|
2016-07-19 13:04:27 +02:00
|
|
|
|
|
|
|
|
|
iter = mnt_new_iter (MNT_ITER_FORWARD);
|
|
|
|
|
while (mnt_table_next_fs (table, iter, &fs) == 0)
|
|
|
|
|
{
|
|
|
|
|
const char *device_path = NULL;
|
|
|
|
|
char *mount_options = NULL;
|
|
|
|
|
unsigned long mount_flags = 0;
|
|
|
|
|
gboolean is_read_only = FALSE;
|
|
|
|
|
|
|
|
|
|
device_path = mnt_fs_get_source (fs);
|
|
|
|
|
if (g_strcmp0 (device_path, "/dev/root") == 0)
|
|
|
|
|
device_path = _resolve_dev_root ();
|
|
|
|
|
|
|
|
|
|
mount_options = mnt_fs_strdup_options (fs);
|
|
|
|
|
if (mount_options)
|
|
|
|
|
{
|
|
|
|
|
mnt_optstr_get_flags (mount_options, &mount_flags, mnt_get_builtin_optmap (MNT_LINUX_MAP));
|
|
|
|
|
g_free (mount_options);
|
|
|
|
|
}
|
|
|
|
|
is_read_only = (mount_flags & MS_RDONLY) ? TRUE : FALSE;
|
|
|
|
|
|
|
|
|
|
mount_entry = create_unix_mount_entry (device_path,
|
|
|
|
|
mnt_fs_get_target (fs),
|
2018-04-26 10:37:33 +02:00
|
|
|
|
mnt_fs_get_root (fs),
|
2016-07-19 13:04:27 +02:00
|
|
|
|
mnt_fs_get_fstype (fs),
|
2018-04-26 10:36:36 +02:00
|
|
|
|
mnt_fs_get_options (fs),
|
2016-07-19 13:04:27 +02:00
|
|
|
|
is_read_only);
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
g_ptr_array_add (return_array, g_steal_pointer (&mount_entry));
|
2016-07-19 13:04:27 +02:00
|
|
|
|
}
|
|
|
|
|
mnt_free_iter (iter);
|
2016-07-27 21:50:54 +02:00
|
|
|
|
|
|
|
|
|
out:
|
2017-11-01 15:21:34 +01:00
|
|
|
|
mnt_free_table (table);
|
2016-07-19 13:04:27 +02:00
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
if (n_entries_out != NULL)
|
|
|
|
|
*n_entries_out = return_array->len;
|
|
|
|
|
|
|
|
|
|
return (GUnixMountEntry **) g_ptr_array_free (g_steal_pointer (&return_array), FALSE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mounts (void)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountEntry **entries = NULL;
|
|
|
|
|
size_t n_entries = 0;
|
|
|
|
|
|
|
|
|
|
entries = _g_unix_mounts_get_from_file (NULL /* default libmount filename */,
|
|
|
|
|
NULL, &n_entries);
|
|
|
|
|
|
|
|
|
|
return unix_mount_entry_array_free_to_list (g_steal_pointer (&entries), n_entries);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-07-19 13:04:27 +02:00
|
|
|
|
#else
|
|
|
|
|
|
2017-08-03 09:50:41 +02:00
|
|
|
|
static const char *
|
2016-07-19 13:04:27 +02:00
|
|
|
|
get_mtab_read_file (void)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
#ifdef _PATH_MOUNTED
|
2011-09-29 21:09:43 +02:00
|
|
|
|
# ifdef __linux__
|
|
|
|
|
return "/proc/mounts";
|
|
|
|
|
# else
|
2007-11-26 17:13:05 +01:00
|
|
|
|
return _PATH_MOUNTED;
|
2011-09-29 21:09:43 +02:00
|
|
|
|
# endif
|
2014-08-18 22:48:28 +02:00
|
|
|
|
#else
|
2007-11-26 17:13:05 +01:00
|
|
|
|
return "/etc/mtab";
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#ifndef HAVE_GETMNTENT_R
|
2007-11-26 17:13:05 +01:00
|
|
|
|
G_LOCK_DEFINE_STATIC(getmntent);
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#endif
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountEntry **
|
|
|
|
|
_g_unix_mounts_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_entries_out)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#ifdef HAVE_GETMNTENT_R
|
|
|
|
|
struct mntent ent;
|
|
|
|
|
char buf[1024];
|
|
|
|
|
#endif
|
2007-11-26 17:13:05 +01:00
|
|
|
|
struct mntent *mntent;
|
|
|
|
|
FILE *file;
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
GUnixMountEntry *mount_entry;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
GHashTable *mounts_hash;
|
2024-07-20 14:53:57 +02:00
|
|
|
|
GPtrArray *return_array = NULL;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = get_mounts_timestamp ();
|
|
|
|
|
|
|
|
|
|
file = setmntent (table_path, "re");
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (file == NULL)
|
|
|
|
|
return NULL;
|
|
|
|
|
|
2024-10-18 11:31:12 +02:00
|
|
|
|
return_array = g_ptr_array_new_null_terminated (0, (GDestroyNotify) g_unix_mount_entry_free, TRUE);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
mounts_hash = g_hash_table_new (g_str_hash, g_str_equal);
|
|
|
|
|
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#ifdef HAVE_GETMNTENT_R
|
|
|
|
|
while ((mntent = getmntent_r (file, &ent, buf, sizeof (buf))) != NULL)
|
|
|
|
|
#else
|
2007-11-26 17:13:05 +01:00
|
|
|
|
G_LOCK (getmntent);
|
|
|
|
|
while ((mntent = getmntent (file)) != NULL)
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#endif
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
2016-07-19 14:31:09 +02:00
|
|
|
|
const char *device_path = NULL;
|
|
|
|
|
gboolean is_read_only = FALSE;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/* ignore any mnt_fsname that is repeated and begins with a '/'
|
|
|
|
|
*
|
|
|
|
|
* We do this to avoid being fooled by --bind mounts, since
|
|
|
|
|
* these have the same device as the location they bind to.
|
2009-02-23 05:30:06 +01:00
|
|
|
|
* It's not an ideal solution to the problem, but it's likely that
|
2007-11-26 17:13:05 +01:00
|
|
|
|
* the most important mountpoint is first and the --bind ones after
|
|
|
|
|
* that aren't as important. So it should work.
|
|
|
|
|
*
|
|
|
|
|
* The '/' is to handle procfs, tmpfs and other no device mounts.
|
|
|
|
|
*/
|
|
|
|
|
if (mntent->mnt_fsname != NULL &&
|
|
|
|
|
mntent->mnt_fsname[0] == '/' &&
|
|
|
|
|
g_hash_table_lookup (mounts_hash, mntent->mnt_fsname))
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
continue;
|
2016-07-19 14:31:09 +02:00
|
|
|
|
|
2013-11-26 12:16:57 +01:00
|
|
|
|
if (g_strcmp0 (mntent->mnt_fsname, "/dev/root") == 0)
|
2016-07-19 14:31:09 +02:00
|
|
|
|
device_path = _resolve_dev_root ();
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
else
|
2016-07-19 14:31:09 +02:00
|
|
|
|
device_path = mntent->mnt_fsname;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#if defined (HAVE_HASMNTOPT)
|
|
|
|
|
if (hasmntopt (mntent, MNTOPT_RO) != NULL)
|
2016-07-19 14:31:09 +02:00
|
|
|
|
is_read_only = TRUE;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#endif
|
2016-07-19 14:31:09 +02:00
|
|
|
|
|
|
|
|
|
mount_entry = create_unix_mount_entry (device_path,
|
|
|
|
|
mntent->mnt_dir,
|
2018-04-26 10:37:33 +02:00
|
|
|
|
NULL,
|
2016-07-19 14:31:09 +02:00
|
|
|
|
mntent->mnt_type,
|
2018-04-26 10:36:36 +02:00
|
|
|
|
mntent->mnt_opts,
|
2016-07-19 14:31:09 +02:00
|
|
|
|
is_read_only);
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
g_hash_table_insert (mounts_hash,
|
|
|
|
|
mount_entry->device_path,
|
|
|
|
|
mount_entry->device_path);
|
2016-07-19 14:31:09 +02:00
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
g_ptr_array_add (return_array, g_steal_pointer (&mount_entry));
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
g_hash_table_destroy (mounts_hash);
|
|
|
|
|
|
|
|
|
|
endmntent (file);
|
|
|
|
|
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#ifndef HAVE_GETMNTENT_R
|
2007-11-26 17:13:05 +01:00
|
|
|
|
G_UNLOCK (getmntent);
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#endif
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
if (n_entries_out != NULL)
|
|
|
|
|
*n_entries_out = return_array->len;
|
|
|
|
|
|
|
|
|
|
return (GUnixMountEntry **) g_ptr_array_free (g_steal_pointer (&return_array), FALSE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mounts (void)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountEntry **entries = NULL;
|
|
|
|
|
size_t n_entries = 0;
|
|
|
|
|
|
|
|
|
|
entries = _g_unix_mounts_get_from_file (get_mtab_read_file (), NULL, &n_entries);
|
|
|
|
|
|
|
|
|
|
return unix_mount_entry_array_free_to_list (g_steal_pointer (&entries), n_entries);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-07-19 13:04:27 +02:00
|
|
|
|
#endif /* HAVE_LIBMOUNT */
|
|
|
|
|
|
2017-08-03 09:50:41 +02:00
|
|
|
|
static const char *
|
2016-07-19 13:04:27 +02:00
|
|
|
|
get_mtab_monitor_file (void)
|
|
|
|
|
{
|
2017-08-03 09:50:41 +02:00
|
|
|
|
static const char *mountinfo_path = NULL;
|
2016-05-20 17:59:02 +02:00
|
|
|
|
#ifdef HAVE_LIBMOUNT
|
|
|
|
|
struct stat buf;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
if (mountinfo_path != NULL)
|
|
|
|
|
return mountinfo_path;
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_LIBMOUNT
|
2017-07-17 15:53:24 +02:00
|
|
|
|
/* The mtab file is still used by some distros, so it has to be monitored in
|
|
|
|
|
* order to avoid races between g_unix_mounts_get and "mounts-changed" signal:
|
|
|
|
|
* https://bugzilla.gnome.org/show_bug.cgi?id=782814
|
|
|
|
|
*/
|
|
|
|
|
if (mnt_has_regular_mtab (&mountinfo_path, NULL))
|
|
|
|
|
{
|
|
|
|
|
return mountinfo_path;
|
|
|
|
|
}
|
|
|
|
|
|
2016-05-20 17:59:02 +02:00
|
|
|
|
if (stat (PROC_MOUNTINFO_PATH, &buf) == 0)
|
|
|
|
|
{
|
|
|
|
|
mountinfo_path = PROC_MOUNTINFO_PATH;
|
|
|
|
|
return mountinfo_path;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
2016-07-19 13:04:27 +02:00
|
|
|
|
#ifdef _PATH_MOUNTED
|
|
|
|
|
# ifdef __linux__
|
2016-05-20 17:59:02 +02:00
|
|
|
|
mountinfo_path = "/proc/mounts";
|
2016-07-19 13:04:27 +02:00
|
|
|
|
# else
|
2016-05-20 17:59:02 +02:00
|
|
|
|
mountinfo_path = _PATH_MOUNTED;
|
2016-07-19 13:04:27 +02:00
|
|
|
|
# endif
|
|
|
|
|
#else
|
2016-05-20 17:59:02 +02:00
|
|
|
|
mountinfo_path = "/etc/mtab";
|
2016-07-19 13:04:27 +02:00
|
|
|
|
#endif
|
2016-05-20 17:59:02 +02:00
|
|
|
|
|
|
|
|
|
return mountinfo_path;
|
2016-07-19 13:04:27 +02:00
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* mnttab.h {{{2 */
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#elif defined (HAVE_SYS_MNTTAB_H)
|
|
|
|
|
|
|
|
|
|
G_LOCK_DEFINE_STATIC(getmntent);
|
|
|
|
|
|
2017-08-03 09:50:41 +02:00
|
|
|
|
static const char *
|
2007-11-26 17:13:05 +01:00
|
|
|
|
get_mtab_read_file (void)
|
|
|
|
|
{
|
|
|
|
|
#ifdef _PATH_MOUNTED
|
|
|
|
|
return _PATH_MOUNTED;
|
|
|
|
|
#else
|
|
|
|
|
return "/etc/mnttab";
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
2017-08-03 09:50:41 +02:00
|
|
|
|
static const char *
|
2007-11-26 17:13:05 +01:00
|
|
|
|
get_mtab_monitor_file (void)
|
|
|
|
|
{
|
|
|
|
|
return get_mtab_read_file ();
|
|
|
|
|
}
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountEntry **
|
|
|
|
|
_g_unix_mounts_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_entries_out)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
struct mnttab mntent;
|
|
|
|
|
FILE *file;
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
GUnixMountEntry *mount_entry;
|
2024-07-20 14:53:57 +02:00
|
|
|
|
GPtrArray *return_array = NULL;
|
|
|
|
|
|
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = get_mounts_timestamp ();
|
|
|
|
|
|
2024-08-20 13:39:15 +02:00
|
|
|
|
file = setmntent (table_path, "re");
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (file == NULL)
|
|
|
|
|
return NULL;
|
2024-07-20 14:53:57 +02:00
|
|
|
|
|
2024-10-18 11:31:12 +02:00
|
|
|
|
return_array = g_ptr_array_new_null_terminated (0, (GDestroyNotify) g_unix_mount_entry_free, TRUE);
|
2024-07-20 14:53:57 +02:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
G_LOCK (getmntent);
|
|
|
|
|
while (! getmntent (file, &mntent))
|
|
|
|
|
{
|
2016-07-19 14:31:09 +02:00
|
|
|
|
gboolean is_read_only = FALSE;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#if defined (HAVE_HASMNTOPT)
|
|
|
|
|
if (hasmntopt (&mntent, MNTOPT_RO) != NULL)
|
2016-07-19 14:31:09 +02:00
|
|
|
|
is_read_only = TRUE;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#endif
|
|
|
|
|
|
2016-07-19 14:31:09 +02:00
|
|
|
|
mount_entry = create_unix_mount_entry (mntent.mnt_special,
|
|
|
|
|
mntent.mnt_mountp,
|
2018-04-26 10:37:33 +02:00
|
|
|
|
NULL,
|
2016-07-19 14:31:09 +02:00
|
|
|
|
mntent.mnt_fstype,
|
2018-04-26 10:36:36 +02:00
|
|
|
|
mntent.mnt_opts,
|
2016-07-19 14:31:09 +02:00
|
|
|
|
is_read_only);
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
g_ptr_array_add (return_array, g_steal_pointer (&mount_entry));
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
endmntent (file);
|
|
|
|
|
|
|
|
|
|
G_UNLOCK (getmntent);
|
2024-07-20 14:53:57 +02:00
|
|
|
|
|
|
|
|
|
if (n_entries_out != NULL)
|
|
|
|
|
*n_entries_out = return_array->len;
|
|
|
|
|
|
|
|
|
|
return (GUnixMountEntry **) g_ptr_array_free (g_steal_pointer (&return_array), FALSE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mounts (void)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountEntry **entries = NULL;
|
|
|
|
|
size_t n_entries = 0;
|
|
|
|
|
|
|
|
|
|
entries = _g_unix_mounts_get_from_file (get_mtab_read_file (), NULL, &n_entries);
|
|
|
|
|
|
|
|
|
|
return unix_mount_entry_array_free_to_list (g_steal_pointer (&entries), n_entries);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* mntctl.h (AIX) {{{2 */
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#elif defined(HAVE_SYS_MNTCTL_H) && defined(HAVE_SYS_VMOUNT_H) && defined(HAVE_SYS_VFS_H)
|
|
|
|
|
|
2017-08-03 09:50:41 +02:00
|
|
|
|
static const char *
|
2007-11-26 17:13:05 +01:00
|
|
|
|
get_mtab_monitor_file (void)
|
|
|
|
|
{
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mounts (void)
|
|
|
|
|
{
|
|
|
|
|
struct vfs_ent *fs_info;
|
|
|
|
|
struct vmount *vmount_info;
|
|
|
|
|
int vmount_number;
|
|
|
|
|
unsigned int vmount_size;
|
|
|
|
|
int current;
|
|
|
|
|
GList *return_list;
|
|
|
|
|
|
|
|
|
|
if (mntctl (MCTL_QUERY, sizeof (vmount_size), &vmount_size) != 0)
|
|
|
|
|
{
|
2018-04-27 17:45:36 +02:00
|
|
|
|
g_warning ("Unable to know the number of mounted volumes");
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
vmount_info = (struct vmount*)g_malloc (vmount_size);
|
|
|
|
|
|
|
|
|
|
vmount_number = mntctl (MCTL_QUERY, vmount_size, vmount_info);
|
|
|
|
|
|
|
|
|
|
if (vmount_info->vmt_revision != VMT_REVISION)
|
2018-04-27 17:45:36 +02:00
|
|
|
|
g_warning ("Bad vmount structure revision number, want %d, got %d", VMT_REVISION, vmount_info->vmt_revision);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
if (vmount_number < 0)
|
|
|
|
|
{
|
2018-04-27 17:45:36 +02:00
|
|
|
|
g_warning ("Unable to recover mounted volumes information");
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
g_free (vmount_info);
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return_list = NULL;
|
|
|
|
|
while (vmount_number > 0)
|
|
|
|
|
{
|
2016-07-19 14:31:09 +02:00
|
|
|
|
gboolean is_read_only = FALSE;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
fs_info = getvfsbytype (vmount_info->vmt_gfstype);
|
|
|
|
|
|
2016-07-19 14:31:09 +02:00
|
|
|
|
/* is_removable = (vmount_info->vmt_flags & MNT_REMOVABLE) ? 1 : 0; */
|
|
|
|
|
is_read_only = (vmount_info->vmt_flags & MNT_READONLY) ? 1 : 0;
|
|
|
|
|
|
|
|
|
|
mount_entry = create_unix_mount_entry (vmt2dataptr (vmount_info, VMT_OBJECT),
|
|
|
|
|
vmt2dataptr (vmount_info, VMT_STUB),
|
2018-04-26 10:37:33 +02:00
|
|
|
|
NULL,
|
2016-07-19 14:31:09 +02:00
|
|
|
|
fs_info == NULL ? "unknown" : fs_info->vfsent_name,
|
2018-04-26 10:36:36 +02:00
|
|
|
|
NULL,
|
2016-07-19 14:31:09 +02:00
|
|
|
|
is_read_only);
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
return_list = g_list_prepend (return_list, mount_entry);
|
|
|
|
|
|
|
|
|
|
vmount_info = (struct vmount *)( (char*)vmount_info
|
|
|
|
|
+ vmount_info->vmt_length);
|
|
|
|
|
vmount_number--;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
g_free (vmount_info);
|
|
|
|
|
|
|
|
|
|
return g_list_reverse (return_list);
|
|
|
|
|
}
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountEntry **
|
|
|
|
|
_g_unix_mounts_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_entries_out)
|
|
|
|
|
{
|
|
|
|
|
/* Not supported on mntctl() systems. */
|
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = 0;
|
|
|
|
|
if (n_entries_out != NULL)
|
|
|
|
|
*n_entries_out = 0;
|
|
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* sys/mount.h {{{2 */
|
2011-09-01 11:10:38 +02:00
|
|
|
|
#elif (defined(HAVE_GETVFSSTAT) || defined(HAVE_GETFSSTAT)) && defined(HAVE_FSTAB_H) && defined(HAVE_SYS_MOUNT_H)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2017-08-03 09:50:41 +02:00
|
|
|
|
static const char *
|
2007-11-26 17:13:05 +01:00
|
|
|
|
get_mtab_monitor_file (void)
|
|
|
|
|
{
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mounts (void)
|
|
|
|
|
{
|
2014-08-18 22:48:28 +02:00
|
|
|
|
#if defined(USE_STATVFS)
|
2011-07-18 18:58:01 +02:00
|
|
|
|
struct statvfs *mntent = NULL;
|
2014-08-18 22:48:28 +02:00
|
|
|
|
#elif defined(USE_STATFS)
|
2011-09-01 11:10:38 +02:00
|
|
|
|
struct statfs *mntent = NULL;
|
2011-07-18 18:58:01 +02:00
|
|
|
|
#else
|
|
|
|
|
#error statfs juggling failed
|
|
|
|
|
#endif
|
2011-09-01 11:10:38 +02:00
|
|
|
|
size_t bufsize;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
int num_mounts, i;
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
GUnixMountEntry *mount_entry;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
GList *return_list;
|
|
|
|
|
|
2011-09-01 11:10:38 +02:00
|
|
|
|
/* Pass NOWAIT to avoid blocking trying to update NFS mounts. */
|
2014-08-18 22:48:28 +02:00
|
|
|
|
#if defined(USE_STATVFS) && defined(HAVE_GETVFSSTAT)
|
2011-09-01 11:10:38 +02:00
|
|
|
|
num_mounts = getvfsstat (NULL, 0, ST_NOWAIT);
|
2014-08-18 22:48:28 +02:00
|
|
|
|
#elif defined(USE_STATFS) && defined(HAVE_GETFSSTAT)
|
2011-09-01 11:10:38 +02:00
|
|
|
|
num_mounts = getfsstat (NULL, 0, MNT_NOWAIT);
|
|
|
|
|
#endif
|
|
|
|
|
if (num_mounts == -1)
|
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
|
|
bufsize = num_mounts * sizeof (*mntent);
|
|
|
|
|
mntent = g_malloc (bufsize);
|
2014-08-18 22:48:28 +02:00
|
|
|
|
#if defined(USE_STATVFS) && defined(HAVE_GETVFSSTAT)
|
2011-09-01 11:10:38 +02:00
|
|
|
|
num_mounts = getvfsstat (mntent, bufsize, ST_NOWAIT);
|
2014-08-18 22:48:28 +02:00
|
|
|
|
#elif defined(USE_STATFS) && defined(HAVE_GETFSSTAT)
|
2011-09-01 11:10:38 +02:00
|
|
|
|
num_mounts = getfsstat (mntent, bufsize, MNT_NOWAIT);
|
|
|
|
|
#endif
|
|
|
|
|
if (num_mounts == -1)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
|
|
return_list = NULL;
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < num_mounts; i++)
|
|
|
|
|
{
|
2016-07-19 14:31:09 +02:00
|
|
|
|
gboolean is_read_only = FALSE;
|
2014-08-18 22:48:28 +02:00
|
|
|
|
|
|
|
|
|
#if defined(USE_STATVFS)
|
2011-09-01 11:10:38 +02:00
|
|
|
|
if (mntent[i].f_flag & ST_RDONLY)
|
2014-08-18 22:48:28 +02:00
|
|
|
|
#elif defined(USE_STATFS)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (mntent[i].f_flags & MNT_RDONLY)
|
2014-08-18 22:48:28 +02:00
|
|
|
|
#else
|
|
|
|
|
#error statfs juggling failed
|
2011-07-18 18:58:01 +02:00
|
|
|
|
#endif
|
2016-07-19 14:31:09 +02:00
|
|
|
|
is_read_only = TRUE;
|
|
|
|
|
|
|
|
|
|
mount_entry = create_unix_mount_entry (mntent[i].f_mntfromname,
|
|
|
|
|
mntent[i].f_mntonname,
|
2018-04-26 10:37:33 +02:00
|
|
|
|
NULL,
|
2016-07-19 14:31:09 +02:00
|
|
|
|
mntent[i].f_fstypename,
|
2018-04-26 10:36:36 +02:00
|
|
|
|
NULL,
|
2016-07-19 14:31:09 +02:00
|
|
|
|
is_read_only);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
return_list = g_list_prepend (return_list, mount_entry);
|
|
|
|
|
}
|
2011-09-01 11:10:38 +02:00
|
|
|
|
|
|
|
|
|
g_free (mntent);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
return g_list_reverse (return_list);
|
|
|
|
|
}
|
2015-01-08 05:49:47 +01:00
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountEntry **
|
|
|
|
|
_g_unix_mounts_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_entries_out)
|
|
|
|
|
{
|
|
|
|
|
/* Not supported on getvfsstat()/getfsstat() systems. */
|
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = 0;
|
|
|
|
|
if (n_entries_out != NULL)
|
|
|
|
|
*n_entries_out = 0;
|
|
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* Interix {{{2 */
|
2009-02-25 17:37:35 +01:00
|
|
|
|
#elif defined(__INTERIX)
|
|
|
|
|
|
2017-08-03 09:50:41 +02:00
|
|
|
|
static const char *
|
2009-02-25 17:37:35 +01:00
|
|
|
|
get_mtab_monitor_file (void)
|
|
|
|
|
{
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mounts (void)
|
|
|
|
|
{
|
|
|
|
|
DIR *dirp;
|
|
|
|
|
GList* return_list = NULL;
|
|
|
|
|
char filename[9 + NAME_MAX];
|
|
|
|
|
|
|
|
|
|
dirp = opendir ("/dev/fs");
|
|
|
|
|
if (!dirp)
|
|
|
|
|
{
|
|
|
|
|
g_warning ("unable to read /dev/fs!");
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
while (1)
|
|
|
|
|
{
|
|
|
|
|
struct statvfs statbuf;
|
|
|
|
|
struct dirent entry;
|
|
|
|
|
struct dirent* result;
|
|
|
|
|
|
|
|
|
|
if (readdir_r (dirp, &entry, &result) || result == NULL)
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
strcpy (filename, "/dev/fs/");
|
|
|
|
|
strcat (filename, entry.d_name);
|
|
|
|
|
|
|
|
|
|
if (statvfs (filename, &statbuf) == 0)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountEntry* mount_entry = g_new0(GUnixMountEntry, 1);
|
|
|
|
|
|
|
|
|
|
mount_entry->mount_path = g_strdup (statbuf.f_mntonname);
|
|
|
|
|
mount_entry->device_path = g_strdup (statbuf.f_mntfromname);
|
|
|
|
|
mount_entry->filesystem_type = g_strdup (statbuf.f_fstypename);
|
|
|
|
|
|
|
|
|
|
if (statbuf.f_flag & ST_RDONLY)
|
|
|
|
|
mount_entry->is_read_only = TRUE;
|
|
|
|
|
|
|
|
|
|
return_list = g_list_prepend(return_list, mount_entry);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return_list = g_list_reverse (return_list);
|
|
|
|
|
|
|
|
|
|
closedir (dirp);
|
|
|
|
|
|
|
|
|
|
return return_list;
|
|
|
|
|
}
|
2015-01-08 05:49:47 +01:00
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountEntry **
|
|
|
|
|
_g_unix_mounts_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_entries_out)
|
|
|
|
|
{
|
|
|
|
|
/* Not supported on Interix systems. */
|
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = 0;
|
|
|
|
|
if (n_entries_out != NULL)
|
|
|
|
|
*n_entries_out = 0;
|
|
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2015-03-25 16:54:03 +01:00
|
|
|
|
/* QNX {{{2 */
|
|
|
|
|
#elif defined (HAVE_QNX)
|
|
|
|
|
|
|
|
|
|
static char *
|
|
|
|
|
get_mtab_monitor_file (void)
|
|
|
|
|
{
|
|
|
|
|
/* TODO: Not implemented */
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountEntry **
|
|
|
|
|
_g_unix_mounts_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_entries_out)
|
|
|
|
|
{
|
|
|
|
|
/* Not implemented, as per _g_get_unix_mounts() below */
|
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = 0;
|
|
|
|
|
if (n_entries_out != NULL)
|
|
|
|
|
*n_entries_out = 0;
|
|
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2015-03-25 16:54:03 +01:00
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mounts (void)
|
|
|
|
|
{
|
|
|
|
|
/* TODO: Not implemented */
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* Common code {{{2 */
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#else
|
|
|
|
|
#error No _g_get_unix_mounts() implementation for system
|
|
|
|
|
#endif
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* GUnixMountPoints (ie: fstab) implementations {{{1 */
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/* _g_get_unix_mount_points():
|
|
|
|
|
* read the fstab.
|
|
|
|
|
* don't return swap and ignore mounts.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
static char *
|
|
|
|
|
get_fstab_file (void)
|
|
|
|
|
{
|
2016-07-19 12:51:55 +02:00
|
|
|
|
#ifdef HAVE_LIBMOUNT
|
|
|
|
|
return (char *) mnt_get_fstab_path ();
|
|
|
|
|
#else
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#if defined(HAVE_SYS_MNTCTL_H) && defined(HAVE_SYS_VMOUNT_H) && defined(HAVE_SYS_VFS_H)
|
|
|
|
|
/* AIX */
|
|
|
|
|
return "/etc/filesystems";
|
|
|
|
|
#elif defined(_PATH_MNTTAB)
|
|
|
|
|
return _PATH_MNTTAB;
|
|
|
|
|
#elif defined(VFSTAB)
|
|
|
|
|
return VFSTAB;
|
|
|
|
|
#else
|
|
|
|
|
return "/etc/fstab";
|
|
|
|
|
#endif
|
2016-07-19 12:51:55 +02:00
|
|
|
|
#endif
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* mntent.h (Linux, GNU, NSS) {{{2 */
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#ifdef HAVE_MNTENT_H
|
2016-07-19 13:05:02 +02:00
|
|
|
|
|
|
|
|
|
#ifdef HAVE_LIBMOUNT
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountPoint **
|
|
|
|
|
_g_unix_mount_points_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_points_out)
|
2016-07-19 13:05:02 +02:00
|
|
|
|
{
|
|
|
|
|
struct libmnt_table *table = NULL;
|
|
|
|
|
struct libmnt_iter* iter = NULL;
|
|
|
|
|
struct libmnt_fs *fs = NULL;
|
|
|
|
|
GUnixMountPoint *mount_point = NULL;
|
2024-07-20 14:53:57 +02:00
|
|
|
|
GPtrArray *return_array = NULL;
|
2016-07-19 13:05:02 +02:00
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = get_mount_points_timestamp ();
|
|
|
|
|
|
|
|
|
|
return_array = g_ptr_array_new_null_terminated (0, (GDestroyNotify) g_unix_mount_point_free, TRUE);
|
2017-05-05 12:33:58 +02:00
|
|
|
|
table = mnt_new_table ();
|
2024-07-20 14:53:57 +02:00
|
|
|
|
if (mnt_table_parse_fstab (table, table_path) < 0)
|
2016-07-27 21:50:54 +02:00
|
|
|
|
goto out;
|
2016-07-19 13:05:02 +02:00
|
|
|
|
|
|
|
|
|
iter = mnt_new_iter (MNT_ITER_FORWARD);
|
|
|
|
|
while (mnt_table_next_fs (table, iter, &fs) == 0)
|
|
|
|
|
{
|
|
|
|
|
const char *device_path = NULL;
|
|
|
|
|
const char *mount_path = NULL;
|
|
|
|
|
const char *mount_fstype = NULL;
|
|
|
|
|
char *mount_options = NULL;
|
|
|
|
|
gboolean is_read_only = FALSE;
|
|
|
|
|
gboolean is_user_mountable = FALSE;
|
|
|
|
|
gboolean is_loopback = FALSE;
|
|
|
|
|
|
|
|
|
|
mount_path = mnt_fs_get_target (fs);
|
|
|
|
|
if ((strcmp (mount_path, "ignore") == 0) ||
|
|
|
|
|
(strcmp (mount_path, "swap") == 0) ||
|
|
|
|
|
(strcmp (mount_path, "none") == 0))
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
mount_fstype = mnt_fs_get_fstype (fs);
|
|
|
|
|
mount_options = mnt_fs_strdup_options (fs);
|
|
|
|
|
if (mount_options)
|
|
|
|
|
{
|
|
|
|
|
unsigned long mount_flags = 0;
|
|
|
|
|
unsigned long userspace_flags = 0;
|
|
|
|
|
|
|
|
|
|
mnt_optstr_get_flags (mount_options, &mount_flags, mnt_get_builtin_optmap (MNT_LINUX_MAP));
|
|
|
|
|
mnt_optstr_get_flags (mount_options, &userspace_flags, mnt_get_builtin_optmap (MNT_USERSPACE_MAP));
|
|
|
|
|
|
|
|
|
|
/* We ignore bind fstab entries, as we ignore bind mounts anyway */
|
|
|
|
|
if (mount_flags & MS_BIND)
|
|
|
|
|
{
|
|
|
|
|
g_free (mount_options);
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
is_read_only = (mount_flags & MS_RDONLY) != 0;
|
|
|
|
|
is_loopback = (userspace_flags & MNT_MS_LOOP) != 0;
|
|
|
|
|
|
|
|
|
|
if ((mount_fstype != NULL && g_strcmp0 ("supermount", mount_fstype) == 0) ||
|
|
|
|
|
((userspace_flags & MNT_MS_USER) &&
|
|
|
|
|
(g_strstr_len (mount_options, -1, "user_xattr") == NULL)) ||
|
|
|
|
|
(userspace_flags & MNT_MS_USERS) ||
|
|
|
|
|
(userspace_flags & MNT_MS_OWNER))
|
|
|
|
|
{
|
|
|
|
|
is_user_mountable = TRUE;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
device_path = mnt_fs_get_source (fs);
|
|
|
|
|
if (g_strcmp0 (device_path, "/dev/root") == 0)
|
|
|
|
|
device_path = _resolve_dev_root ();
|
|
|
|
|
|
|
|
|
|
mount_point = create_unix_mount_point (device_path,
|
|
|
|
|
mount_path,
|
|
|
|
|
mount_fstype,
|
|
|
|
|
mount_options,
|
|
|
|
|
is_read_only,
|
|
|
|
|
is_user_mountable,
|
|
|
|
|
is_loopback);
|
|
|
|
|
if (mount_options)
|
|
|
|
|
g_free (mount_options);
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
g_ptr_array_add (return_array, g_steal_pointer (&mount_point));
|
2016-07-19 13:05:02 +02:00
|
|
|
|
}
|
|
|
|
|
mnt_free_iter (iter);
|
2016-07-27 21:50:54 +02:00
|
|
|
|
|
|
|
|
|
out:
|
2017-11-01 15:21:34 +01:00
|
|
|
|
mnt_free_table (table);
|
2016-07-19 13:05:02 +02:00
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
if (n_points_out != NULL)
|
|
|
|
|
*n_points_out = return_array->len;
|
2016-07-19 13:05:02 +02:00
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
return (GUnixMountPoint **) g_ptr_array_free (g_steal_pointer (&return_array), FALSE);
|
|
|
|
|
}
|
2016-07-19 13:05:02 +02:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mount_points (void)
|
2024-07-20 14:53:57 +02:00
|
|
|
|
{
|
|
|
|
|
GUnixMountPoint **points = NULL;
|
|
|
|
|
size_t n_points = 0;
|
|
|
|
|
|
|
|
|
|
points = _g_unix_mount_points_get_from_file (NULL /* default libmount filename */,
|
|
|
|
|
NULL, &n_points);
|
|
|
|
|
|
|
|
|
|
return unix_mount_point_array_free_to_list (g_steal_pointer (&points), n_points);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
|
|
static GUnixMountPoint **
|
|
|
|
|
_g_unix_mount_points_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_points_out)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#ifdef HAVE_GETMNTENT_R
|
|
|
|
|
struct mntent ent;
|
|
|
|
|
char buf[1024];
|
|
|
|
|
#endif
|
2007-11-26 17:13:05 +01:00
|
|
|
|
struct mntent *mntent;
|
|
|
|
|
FILE *file;
|
2016-05-20 16:58:56 +02:00
|
|
|
|
GUnixMountPoint *mount_point;
|
2024-07-20 14:53:57 +02:00
|
|
|
|
GPtrArray *return_array = NULL;
|
|
|
|
|
|
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = get_mount_points_timestamp ();
|
|
|
|
|
|
|
|
|
|
file = setmntent (table_path, "re");
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (file == NULL)
|
2024-07-20 14:53:57 +02:00
|
|
|
|
{
|
|
|
|
|
if (n_points_out != NULL)
|
|
|
|
|
*n_points_out = 0;
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return_array = g_ptr_array_new_null_terminated (0, (GDestroyNotify) g_unix_mount_point_free, TRUE);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#ifdef HAVE_GETMNTENT_R
|
|
|
|
|
while ((mntent = getmntent_r (file, &ent, buf, sizeof (buf))) != NULL)
|
|
|
|
|
#else
|
2007-11-26 17:13:05 +01:00
|
|
|
|
G_LOCK (getmntent);
|
|
|
|
|
while ((mntent = getmntent (file)) != NULL)
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#endif
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
2016-05-20 16:58:56 +02:00
|
|
|
|
const char *device_path = NULL;
|
|
|
|
|
gboolean is_read_only = FALSE;
|
|
|
|
|
gboolean is_user_mountable = FALSE;
|
|
|
|
|
gboolean is_loopback = FALSE;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if ((strcmp (mntent->mnt_dir, "ignore") == 0) ||
|
2011-09-20 16:07:35 +02:00
|
|
|
|
(strcmp (mntent->mnt_dir, "swap") == 0) ||
|
|
|
|
|
(strcmp (mntent->mnt_dir, "none") == 0))
|
2007-11-26 17:13:05 +01:00
|
|
|
|
continue;
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
|
2013-04-05 16:18:28 +02:00
|
|
|
|
#ifdef HAVE_HASMNTOPT
|
2013-01-23 12:07:10 +01:00
|
|
|
|
/* We ignore bind fstab entries, as we ignore bind mounts anyway */
|
|
|
|
|
if (hasmntopt (mntent, "bind"))
|
|
|
|
|
continue;
|
2013-04-05 16:18:28 +02:00
|
|
|
|
#endif
|
2013-01-23 12:07:10 +01:00
|
|
|
|
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
if (strcmp (mntent->mnt_fsname, "/dev/root") == 0)
|
2016-05-20 16:58:56 +02:00
|
|
|
|
device_path = _resolve_dev_root ();
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
else
|
2016-05-20 16:58:56 +02:00
|
|
|
|
device_path = mntent->mnt_fsname;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#ifdef HAVE_HASMNTOPT
|
|
|
|
|
if (hasmntopt (mntent, MNTOPT_RO) != NULL)
|
2016-05-20 16:58:56 +02:00
|
|
|
|
is_read_only = TRUE;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (hasmntopt (mntent, "loop") != NULL)
|
2016-05-20 16:58:56 +02:00
|
|
|
|
is_loopback = TRUE;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#endif
|
2016-05-20 16:58:56 +02:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if ((mntent->mnt_type != NULL && strcmp ("supermount", mntent->mnt_type) == 0)
|
|
|
|
|
#ifdef HAVE_HASMNTOPT
|
|
|
|
|
|| (hasmntopt (mntent, "user") != NULL
|
|
|
|
|
&& hasmntopt (mntent, "user") != hasmntopt (mntent, "user_xattr"))
|
|
|
|
|
|| hasmntopt (mntent, "users") != NULL
|
|
|
|
|
|| hasmntopt (mntent, "owner") != NULL
|
|
|
|
|
#endif
|
|
|
|
|
)
|
2016-05-20 16:58:56 +02:00
|
|
|
|
is_user_mountable = TRUE;
|
|
|
|
|
|
|
|
|
|
mount_point = create_unix_mount_point (device_path,
|
|
|
|
|
mntent->mnt_dir,
|
|
|
|
|
mntent->mnt_type,
|
|
|
|
|
mntent->mnt_opts,
|
|
|
|
|
is_read_only,
|
|
|
|
|
is_user_mountable,
|
|
|
|
|
is_loopback);
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
g_ptr_array_add (return_array, g_steal_pointer (&mount_point));
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
endmntent (file);
|
2008-02-10 06:20:00 +01:00
|
|
|
|
|
|
|
|
|
#ifndef HAVE_GETMNTENT_R
|
2007-11-26 17:13:05 +01:00
|
|
|
|
G_UNLOCK (getmntent);
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#endif
|
2024-07-20 14:53:57 +02:00
|
|
|
|
|
|
|
|
|
if (n_points_out != NULL)
|
|
|
|
|
*n_points_out = return_array->len;
|
|
|
|
|
|
|
|
|
|
return (GUnixMountPoint **) g_ptr_array_free (g_steal_pointer (&return_array), FALSE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mount_points (void)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountPoint **points = NULL;
|
|
|
|
|
size_t n_points = 0;
|
|
|
|
|
|
|
|
|
|
points = _g_unix_mount_points_get_from_file (get_fstab_file (),
|
|
|
|
|
NULL, &n_points);
|
|
|
|
|
|
|
|
|
|
return unix_mount_point_array_free_to_list (g_steal_pointer (&points), n_points);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-07-19 13:05:02 +02:00
|
|
|
|
#endif /* HAVE_LIBMOUNT */
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* mnttab.h {{{2 */
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#elif defined (HAVE_SYS_MNTTAB_H)
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountPoint **
|
|
|
|
|
_g_unix_mount_points_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_points_out)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
struct mnttab mntent;
|
|
|
|
|
FILE *file;
|
2016-05-20 16:58:56 +02:00
|
|
|
|
GUnixMountPoint *mount_point;
|
2024-07-20 14:53:57 +02:00
|
|
|
|
GPtrArray *return_array = NULL;
|
|
|
|
|
|
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = get_mount_points_timestamp ();
|
|
|
|
|
|
|
|
|
|
file = setmntent (table_path, "re");
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (file == NULL)
|
2024-07-20 14:53:57 +02:00
|
|
|
|
{
|
|
|
|
|
if (n_points_out != NULL)
|
|
|
|
|
*n_points_out = 0;
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
return_array = g_ptr_array_new_null_terminated (0, (GDestroyNotify) g_unix_mount_point_free, TRUE);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
G_LOCK (getmntent);
|
|
|
|
|
while (! getmntent (file, &mntent))
|
|
|
|
|
{
|
2016-05-20 16:58:56 +02:00
|
|
|
|
gboolean is_read_only = FALSE;
|
|
|
|
|
gboolean is_user_mountable = FALSE;
|
|
|
|
|
gboolean is_loopback = FALSE;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if ((strcmp (mntent.mnt_mountp, "ignore") == 0) ||
|
2011-09-20 16:07:35 +02:00
|
|
|
|
(strcmp (mntent.mnt_mountp, "swap") == 0) ||
|
|
|
|
|
(strcmp (mntent.mnt_mountp, "none") == 0))
|
2007-11-26 17:13:05 +01:00
|
|
|
|
continue;
|
2016-05-20 16:58:56 +02:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#ifdef HAVE_HASMNTOPT
|
|
|
|
|
if (hasmntopt (&mntent, MNTOPT_RO) != NULL)
|
2016-05-20 16:58:56 +02:00
|
|
|
|
is_read_only = TRUE;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (hasmntopt (&mntent, "lofs") != NULL)
|
2016-05-20 16:58:56 +02:00
|
|
|
|
is_loopback = TRUE;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#endif
|
2016-05-20 16:58:56 +02:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if ((mntent.mnt_fstype != NULL)
|
|
|
|
|
#ifdef HAVE_HASMNTOPT
|
|
|
|
|
|| (hasmntopt (&mntent, "user") != NULL
|
|
|
|
|
&& hasmntopt (&mntent, "user") != hasmntopt (&mntent, "user_xattr"))
|
|
|
|
|
|| hasmntopt (&mntent, "users") != NULL
|
|
|
|
|
|| hasmntopt (&mntent, "owner") != NULL
|
|
|
|
|
#endif
|
|
|
|
|
)
|
2016-05-20 16:58:56 +02:00
|
|
|
|
is_user_mountable = TRUE;
|
|
|
|
|
|
|
|
|
|
mount_point = create_unix_mount_point (mntent.mnt_special,
|
|
|
|
|
mntent.mnt_mountp,
|
|
|
|
|
mntent.mnt_fstype,
|
|
|
|
|
mntent.mnt_mntopts,
|
|
|
|
|
is_read_only,
|
|
|
|
|
is_user_mountable,
|
|
|
|
|
is_loopback);
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
g_ptr_array_add (return_array, g_steal_pointer (&mount_point));
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
endmntent (file);
|
|
|
|
|
G_UNLOCK (getmntent);
|
2024-07-20 14:53:57 +02:00
|
|
|
|
|
|
|
|
|
if (n_points_out != NULL)
|
|
|
|
|
*n_points_out = return_array->len;
|
|
|
|
|
|
|
|
|
|
return (GUnixMountPoint **) g_ptr_array_free (g_steal_pointer (&return_array), FALSE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mount_points (void)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountPoint **points = NULL;
|
|
|
|
|
size_t n_points = 0;
|
|
|
|
|
|
|
|
|
|
points = _g_unix_mount_points_get_from_file (get_fstab_file (),
|
|
|
|
|
NULL, &n_points);
|
|
|
|
|
|
|
|
|
|
return unix_mount_point_array_free_to_list (g_steal_pointer (&points), n_points);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
2015-01-08 05:49:47 +01:00
|
|
|
|
|
|
|
|
|
/* mntctl.h (AIX) {{{2 */
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#elif defined(HAVE_SYS_MNTCTL_H) && defined(HAVE_SYS_VMOUNT_H) && defined(HAVE_SYS_VFS_H)
|
|
|
|
|
|
|
|
|
|
/* functions to parse /etc/filesystems on aix */
|
|
|
|
|
|
|
|
|
|
/* read character, ignoring comments (begin with '*', end with '\n' */
|
|
|
|
|
static int
|
|
|
|
|
aix_fs_getc (FILE *fd)
|
|
|
|
|
{
|
|
|
|
|
int c;
|
|
|
|
|
|
|
|
|
|
while ((c = getc (fd)) == '*')
|
|
|
|
|
{
|
|
|
|
|
while (((c = getc (fd)) != '\n') && (c != EOF))
|
|
|
|
|
;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* eat all continuous spaces in a file */
|
|
|
|
|
static int
|
|
|
|
|
aix_fs_ignorespace (FILE *fd)
|
|
|
|
|
{
|
|
|
|
|
int c;
|
|
|
|
|
|
|
|
|
|
while ((c = aix_fs_getc (fd)) != EOF)
|
|
|
|
|
{
|
|
|
|
|
if (!g_ascii_isspace (c))
|
|
|
|
|
{
|
|
|
|
|
ungetc (c,fd);
|
|
|
|
|
return c;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return EOF;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* read one word from file */
|
|
|
|
|
static int
|
2007-11-30 06:11:25 +01:00
|
|
|
|
aix_fs_getword (FILE *fd,
|
|
|
|
|
char *word)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
int c;
|
|
|
|
|
|
|
|
|
|
aix_fs_ignorespace (fd);
|
|
|
|
|
|
|
|
|
|
while (((c = aix_fs_getc (fd)) != EOF) && !g_ascii_isspace (c))
|
|
|
|
|
{
|
|
|
|
|
if (c == '"')
|
|
|
|
|
{
|
|
|
|
|
while (((c = aix_fs_getc (fd)) != EOF) && (c != '"'))
|
|
|
|
|
*word++ = c;
|
|
|
|
|
else
|
|
|
|
|
*word++ = c;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
*word = 0;
|
|
|
|
|
|
|
|
|
|
return c;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
|
char mnt_mount[PATH_MAX];
|
|
|
|
|
char mnt_special[PATH_MAX];
|
|
|
|
|
char mnt_fstype[16];
|
|
|
|
|
char mnt_options[128];
|
|
|
|
|
} AixMountTableEntry;
|
|
|
|
|
|
|
|
|
|
/* read mount points properties */
|
|
|
|
|
static int
|
2007-11-30 06:11:25 +01:00
|
|
|
|
aix_fs_get (FILE *fd,
|
|
|
|
|
AixMountTableEntry *prop)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
static char word[PATH_MAX] = { 0 };
|
|
|
|
|
char value[PATH_MAX];
|
|
|
|
|
|
|
|
|
|
/* read stanza */
|
|
|
|
|
if (word[0] == 0)
|
|
|
|
|
{
|
|
|
|
|
if (aix_fs_getword (fd, word) == EOF)
|
|
|
|
|
return EOF;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
word[strlen(word) - 1] = 0;
|
|
|
|
|
strcpy (prop->mnt_mount, word);
|
|
|
|
|
|
|
|
|
|
/* read attributes and value */
|
|
|
|
|
|
|
|
|
|
while (aix_fs_getword (fd, word) != EOF)
|
|
|
|
|
{
|
|
|
|
|
/* test if is attribute or new stanza */
|
|
|
|
|
if (word[strlen(word) - 1] == ':')
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
/* read "=" */
|
|
|
|
|
aix_fs_getword (fd, value);
|
|
|
|
|
|
|
|
|
|
/* read value */
|
|
|
|
|
aix_fs_getword (fd, value);
|
|
|
|
|
|
|
|
|
|
if (strcmp (word, "dev") == 0)
|
|
|
|
|
strcpy (prop->mnt_special, value);
|
|
|
|
|
else if (strcmp (word, "vfs") == 0)
|
|
|
|
|
strcpy (prop->mnt_fstype, value);
|
|
|
|
|
else if (strcmp (word, "options") == 0)
|
|
|
|
|
strcpy(prop->mnt_options, value);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
static GUnixMountPoint **
|
|
|
|
|
_g_unix_mount_points_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_points_out)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
struct mntent *mntent;
|
|
|
|
|
FILE *file;
|
2016-05-20 16:58:56 +02:00
|
|
|
|
GUnixMountPoint *mount_point;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
AixMountTableEntry mntent;
|
2024-07-20 14:53:57 +02:00
|
|
|
|
GPtrArray *return_array = NULL;
|
|
|
|
|
|
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = get_mount_points_timestamp ();
|
|
|
|
|
|
|
|
|
|
file = setmntent (table_path, "re");
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (file == NULL)
|
2024-07-20 14:53:57 +02:00
|
|
|
|
{
|
|
|
|
|
if (n_points_out != NULL)
|
|
|
|
|
*n_points_out = 0;
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return_array = g_ptr_array_new_null_terminated (0, (GDestroyNotify) g_unix_mount_point_free, TRUE);
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
while (!aix_fs_get (file, &mntent))
|
|
|
|
|
{
|
|
|
|
|
if (strcmp ("cdrfs", mntent.mnt_fstype) == 0)
|
|
|
|
|
{
|
2016-05-20 16:58:56 +02:00
|
|
|
|
mount_point = create_unix_mount_point (mntent.mnt_special,
|
|
|
|
|
mntent.mnt_mount,
|
|
|
|
|
mntent.mnt_fstype,
|
|
|
|
|
mntent.mnt_options,
|
|
|
|
|
TRUE,
|
|
|
|
|
TRUE,
|
|
|
|
|
FALSE);
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
g_ptr_array_add (return_array, g_steal_pointer (&mount_point));
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
endmntent (file);
|
2024-07-20 14:53:57 +02:00
|
|
|
|
|
|
|
|
|
if (n_points_out != NULL)
|
|
|
|
|
*n_points_out = return_array->len;
|
|
|
|
|
|
|
|
|
|
return (GUnixMountPoint **) g_ptr_array_free (g_steal_pointer (&return_array), FALSE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mount_points (void)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountPoint **points = NULL;
|
|
|
|
|
size_t n_points = 0;
|
|
|
|
|
|
|
|
|
|
points = _g_unix_mount_points_get_from_file (get_fstab_file (),
|
|
|
|
|
NULL, &n_points);
|
|
|
|
|
|
|
|
|
|
return unix_mount_point_array_free_to_list (g_steal_pointer (&points), n_points);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
2011-09-01 11:10:38 +02:00
|
|
|
|
#elif (defined(HAVE_GETVFSSTAT) || defined(HAVE_GETFSSTAT)) && defined(HAVE_FSTAB_H) && defined(HAVE_SYS_MOUNT_H)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
static GList *
|
|
|
|
|
_g_get_unix_mount_points (void)
|
|
|
|
|
{
|
|
|
|
|
struct fstab *fstab = NULL;
|
2016-05-20 16:58:56 +02:00
|
|
|
|
GUnixMountPoint *mount_point;
|
2022-06-25 17:46:08 +02:00
|
|
|
|
GList *return_list = NULL;
|
|
|
|
|
G_LOCK_DEFINE_STATIC (fsent);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#ifdef HAVE_SYS_SYSCTL_H
|
2022-06-25 18:01:30 +02:00
|
|
|
|
uid_t uid = getuid ();
|
2007-11-26 17:13:05 +01:00
|
|
|
|
int usermnt = 0;
|
|
|
|
|
struct stat sb;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_SYS_SYSCTL_H
|
|
|
|
|
#if defined(HAVE_SYSCTLBYNAME)
|
2013-02-11 17:12:42 +01:00
|
|
|
|
{
|
|
|
|
|
size_t len = sizeof(usermnt);
|
|
|
|
|
|
|
|
|
|
sysctlbyname ("vfs.usermount", &usermnt, &len, NULL, 0);
|
|
|
|
|
}
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#elif defined(CTL_VFS) && defined(VFS_USERMOUNT)
|
|
|
|
|
{
|
|
|
|
|
int mib[2];
|
2013-02-11 17:12:42 +01:00
|
|
|
|
size_t len = sizeof(usermnt);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
mib[0] = CTL_VFS;
|
|
|
|
|
mib[1] = VFS_USERMOUNT;
|
|
|
|
|
sysctl (mib, 2, &usermnt, &len, NULL, 0);
|
|
|
|
|
}
|
|
|
|
|
#elif defined(CTL_KERN) && defined(KERN_USERMOUNT)
|
|
|
|
|
{
|
|
|
|
|
int mib[2];
|
2013-02-11 17:12:42 +01:00
|
|
|
|
size_t len = sizeof(usermnt);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
mib[0] = CTL_KERN;
|
|
|
|
|
mib[1] = KERN_USERMOUNT;
|
|
|
|
|
sysctl (mib, 2, &usermnt, &len, NULL, 0);
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
#endif
|
2022-06-25 17:46:08 +02:00
|
|
|
|
|
|
|
|
|
G_LOCK (fsent);
|
|
|
|
|
if (!setfsent ())
|
|
|
|
|
{
|
|
|
|
|
G_UNLOCK (fsent);
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
while ((fstab = getfsent ()) != NULL)
|
|
|
|
|
{
|
2016-05-20 16:58:56 +02:00
|
|
|
|
gboolean is_read_only = FALSE;
|
|
|
|
|
gboolean is_user_mountable = FALSE;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (strcmp (fstab->fs_vfstype, "swap") == 0)
|
|
|
|
|
continue;
|
2016-05-20 16:58:56 +02:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (strcmp (fstab->fs_type, "ro") == 0)
|
2016-05-20 16:58:56 +02:00
|
|
|
|
is_read_only = TRUE;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
#ifdef HAVE_SYS_SYSCTL_H
|
|
|
|
|
if (usermnt != 0)
|
2022-06-25 18:01:30 +02:00
|
|
|
|
{
|
|
|
|
|
if (uid == 0 ||
|
|
|
|
|
(stat (fstab->fs_file, &sb) == 0 && sb.st_uid == uid))
|
|
|
|
|
{
|
|
|
|
|
is_user_mountable = TRUE;
|
|
|
|
|
}
|
|
|
|
|
}
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#endif
|
|
|
|
|
|
2016-05-20 16:58:56 +02:00
|
|
|
|
mount_point = create_unix_mount_point (fstab->fs_spec,
|
|
|
|
|
fstab->fs_file,
|
|
|
|
|
fstab->fs_vfstype,
|
|
|
|
|
fstab->fs_mntops,
|
|
|
|
|
is_read_only,
|
|
|
|
|
is_user_mountable,
|
|
|
|
|
FALSE);
|
|
|
|
|
|
|
|
|
|
return_list = g_list_prepend (return_list, mount_point);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
2022-06-25 17:46:08 +02:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
endfsent ();
|
2022-06-25 17:46:08 +02:00
|
|
|
|
G_UNLOCK (fsent);
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
return g_list_reverse (return_list);
|
|
|
|
|
}
|
2024-07-20 14:53:57 +02:00
|
|
|
|
|
|
|
|
|
static GUnixMountPoint **
|
|
|
|
|
_g_unix_mount_points_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_points_out)
|
|
|
|
|
{
|
|
|
|
|
/* Not supported on getfsent() systems. */
|
|
|
|
|
if (time_read_out != NULL)
|
|
|
|
|
*time_read_out = 0;
|
|
|
|
|
if (n_points_out != NULL)
|
|
|
|
|
*n_points_out = 0;
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* Common code {{{2 */
|
2007-11-26 17:13:05 +01:00
|
|
|
|
#else
|
|
|
|
|
#error No g_get_mount_table() implementation for system
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
static guint64
|
|
|
|
|
get_mounts_timestamp (void)
|
|
|
|
|
{
|
|
|
|
|
const char *monitor_file;
|
|
|
|
|
struct stat buf;
|
2020-02-10 16:00:42 +01:00
|
|
|
|
guint64 timestamp = 0;
|
|
|
|
|
|
|
|
|
|
G_LOCK (proc_mounts_source);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
monitor_file = get_mtab_monitor_file ();
|
2017-09-08 18:42:14 +02:00
|
|
|
|
/* Don't return mtime for /proc/ files */
|
|
|
|
|
if (monitor_file && !g_str_has_prefix (monitor_file, "/proc/"))
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
if (stat (monitor_file, &buf) == 0)
|
2020-02-10 16:00:42 +01:00
|
|
|
|
timestamp = buf.st_mtime;
|
2014-08-18 22:48:28 +02:00
|
|
|
|
}
|
2017-09-08 18:42:14 +02:00
|
|
|
|
else if (proc_mounts_watch_is_running ())
|
2014-08-18 22:48:28 +02:00
|
|
|
|
{
|
2017-09-08 18:42:14 +02:00
|
|
|
|
/* it's being monitored by poll, so return mount_poller_time */
|
2020-02-10 16:00:42 +01:00
|
|
|
|
timestamp = mount_poller_time;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
2017-09-08 18:42:14 +02:00
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
/* Case of /proc/ file not being monitored - Be on the safe side and
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* send a new timestamp to force g_unix_mount_entries_changed_since() to
|
2017-09-08 18:42:14 +02:00
|
|
|
|
* return TRUE so any application caches depending on it (like eg.
|
|
|
|
|
* the one in GIO) get invalidated and don't hold possibly outdated
|
|
|
|
|
* data - see Bug 787731 */
|
2020-02-10 16:00:42 +01:00
|
|
|
|
timestamp = g_get_monotonic_time ();
|
2017-09-08 18:42:14 +02:00
|
|
|
|
}
|
2020-02-10 16:00:42 +01:00
|
|
|
|
|
|
|
|
|
G_UNLOCK (proc_mounts_source);
|
|
|
|
|
|
|
|
|
|
return timestamp;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static guint64
|
|
|
|
|
get_mount_points_timestamp (void)
|
|
|
|
|
{
|
|
|
|
|
const char *monitor_file;
|
|
|
|
|
struct stat buf;
|
|
|
|
|
|
|
|
|
|
monitor_file = get_fstab_file ();
|
|
|
|
|
if (monitor_file)
|
|
|
|
|
{
|
|
|
|
|
if (stat (monitor_file, &buf) == 0)
|
2014-08-18 22:48:28 +02:00
|
|
|
|
return (guint64)buf.st_mtime;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2017-03-23 12:46:56 +01:00
|
|
|
|
* g_unix_mounts_get:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @time_read: (out) (optional): return location for a timestamp
|
2010-06-16 03:57:57 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Gets a list of [struct@GioUnix.MountEntry] instances representing the Unix
|
|
|
|
|
* mounts.
|
2010-06-16 03:57:57 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* If @time_read is set, it will be filled with the mount timestamp, allowing
|
|
|
|
|
* for checking if the mounts have changed with
|
|
|
|
|
* [func@GioUnix.mount_entries_changed_since].
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (element-type GUnixMountEntry) (transfer full): a list of the
|
|
|
|
|
* Unix mounts
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.mount_entries_get] instead.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*/
|
2007-11-26 17:13:05 +01:00
|
|
|
|
GList *
|
2007-12-17 15:59:23 +01:00
|
|
|
|
g_unix_mounts_get (guint64 *time_read)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entries_get (time_read);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entries_get:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @time_read: (out) (optional): return location for a timestamp
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Gets a list of [struct@GioUnix.MountEntry] instances representing the Unix
|
|
|
|
|
* mounts.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* If @time_read is set, it will be filled with the mount timestamp, allowing
|
|
|
|
|
* for checking if the mounts have changed with
|
|
|
|
|
* [func@GioUnix.mount_entries_changed_since].
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (element-type GUnixMountEntry) (transfer full): a list of the
|
|
|
|
|
* Unix mounts
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
GList *
|
|
|
|
|
g_unix_mount_entries_get (guint64 *time_read)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
if (time_read)
|
|
|
|
|
*time_read = get_mounts_timestamp ();
|
|
|
|
|
|
|
|
|
|
return _g_get_unix_mounts ();
|
|
|
|
|
}
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mounts_get_from_file:
|
|
|
|
|
* @table_path: path to the mounts table file (for example `/proc/self/mountinfo`)
|
|
|
|
|
* @time_read_out: (optional) (out caller-allocates): return location for the
|
|
|
|
|
* modification time of @table_path
|
|
|
|
|
* @n_entries_out: (optional) (out caller-allocates): return location for the
|
|
|
|
|
* number of mount entries returned
|
|
|
|
|
*
|
|
|
|
|
* Gets an array of [struct@Gio.UnixMountEntry]s containing the Unix mounts
|
|
|
|
|
* listed in @table_path.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* This is a generalized version of [func@GioUnix.mount_entries_get], mainly
|
|
|
|
|
* intended for internal testing use. Note that [func@GioUnix.mount_entries_get]
|
|
|
|
|
* may parse multiple hierarchical table files, so this function is not a direct
|
|
|
|
|
* superset of its functionality.
|
2024-07-20 14:53:57 +02:00
|
|
|
|
*
|
|
|
|
|
* If there is an error reading or parsing the file, `NULL` will be returned
|
|
|
|
|
* and both out parameters will be set to `0`.
|
|
|
|
|
*
|
|
|
|
|
* Returns: (transfer full) (array length=n_entries_out) (nullable): mount
|
|
|
|
|
* entries, or `NULL` if there was an error loading them
|
|
|
|
|
* Since: 2.82
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.mount_entries_get_from_file] instead.
|
2024-07-20 14:53:57 +02:00
|
|
|
|
*/
|
|
|
|
|
GUnixMountEntry **
|
|
|
|
|
g_unix_mounts_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_entries_out)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entries_get_from_file (table_path, time_read_out, n_entries_out);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entries_get_from_file:
|
|
|
|
|
* @table_path: path to the mounts table file (for example `/proc/self/mountinfo`)
|
|
|
|
|
* @time_read_out: (optional) (out caller-allocates): return location for the
|
|
|
|
|
* modification time of @table_path
|
|
|
|
|
* @n_entries_out: (optional) (out caller-allocates): return location for the
|
|
|
|
|
* number of mount entries returned
|
|
|
|
|
*
|
|
|
|
|
* Gets an array of [struct@Gio.UnixMountEntry]s containing the Unix mounts
|
|
|
|
|
* listed in @table_path.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* This is a generalized version of [func@GioUnix.mount_entries_get], mainly
|
|
|
|
|
* intended for internal testing use. Note that [func@GioUnix.mount_entries_get]
|
|
|
|
|
* may parse multiple hierarchical table files, so this function is not a direct
|
|
|
|
|
* superset of its functionality.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
|
|
|
|
* If there is an error reading or parsing the file, `NULL` will be returned
|
|
|
|
|
* and both out parameters will be set to `0`.
|
|
|
|
|
*
|
|
|
|
|
* Returns: (transfer full) (array length=n_entries_out) (nullable): mount
|
|
|
|
|
* entries, or `NULL` if there was an error loading them
|
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
GUnixMountEntry **
|
|
|
|
|
g_unix_mount_entries_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_entries_out)
|
2024-07-20 14:53:57 +02:00
|
|
|
|
{
|
|
|
|
|
return _g_unix_mounts_get_from_file (table_path, time_read_out, n_entries_out);
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/**
|
2017-03-23 12:46:56 +01:00
|
|
|
|
* g_unix_mount_at:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_path: (type filename): path for a possible Unix mount
|
|
|
|
|
* @time_read: (out) (optional): return location for a timestamp
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Gets a [struct@GioUnix.MountEntry] for a given mount path.
|
|
|
|
|
*
|
|
|
|
|
* If @time_read is set, it will be filled with a Unix timestamp for checking
|
|
|
|
|
* if the mounts have changed since with
|
|
|
|
|
* [func@GioUnix.mount_entries_changed_since].
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2019-03-22 10:51:24 +01:00
|
|
|
|
* If more mounts have the same mount path, the last matching mount
|
|
|
|
|
* is returned.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* This will return `NULL` if there is no mount point at @mount_path.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full) (nullable): a [struct@GioUnix.MountEntry]
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.at] instead.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
**/
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
GUnixMountEntry *
|
2007-12-17 15:59:23 +01:00
|
|
|
|
g_unix_mount_at (const char *mount_path,
|
|
|
|
|
guint64 *time_read)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_at (mount_path, time_read);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_at:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_path: (type filename): path for a possible Unix mount
|
|
|
|
|
* @time_read: (out) (optional): return location for a timestamp
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Gets a [struct@GioUnix.MountEntry] for a given mount path.
|
|
|
|
|
*
|
|
|
|
|
* If @time_read is set, it will be filled with a Unix timestamp for checking
|
|
|
|
|
* if the mounts have changed since with
|
|
|
|
|
* [func@GioUnix.mount_entries_changed_since].
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
|
|
|
|
* If more mounts have the same mount path, the last matching mount
|
|
|
|
|
* is returned.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* This will return `NULL` if there is no mount point at @mount_path.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full) (nullable): a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
**/
|
|
|
|
|
GUnixMountEntry *
|
|
|
|
|
g_unix_mount_entry_at (const char *mount_path,
|
|
|
|
|
guint64 *time_read)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
GList *mounts, *l;
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
GUnixMountEntry *mount_entry, *found;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2024-10-18 11:31:12 +02:00
|
|
|
|
mounts = g_unix_mount_entries_get (time_read);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
|
|
|
|
found = NULL;
|
|
|
|
|
for (l = mounts; l != NULL; l = l->next)
|
|
|
|
|
{
|
|
|
|
|
mount_entry = l->data;
|
|
|
|
|
|
2019-03-22 10:51:24 +01:00
|
|
|
|
if (strcmp (mount_path, mount_entry->mount_path) == 0)
|
|
|
|
|
{
|
|
|
|
|
if (found != NULL)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
g_unix_mount_entry_free (found);
|
2019-03-22 10:51:24 +01:00
|
|
|
|
|
|
|
|
|
found = mount_entry;
|
|
|
|
|
}
|
2007-11-26 17:13:05 +01:00
|
|
|
|
else
|
2024-10-18 11:31:12 +02:00
|
|
|
|
g_unix_mount_entry_free (mount_entry);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
g_list_free (mounts);
|
|
|
|
|
|
|
|
|
|
return found;
|
|
|
|
|
}
|
|
|
|
|
|
2016-09-29 10:45:50 +02:00
|
|
|
|
/**
|
2017-03-23 12:46:56 +01:00
|
|
|
|
* g_unix_mount_for:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @file_path: (type filename): file path on some Unix mount
|
|
|
|
|
* @time_read: (out) (optional): return location for a timestamp
|
2016-09-29 10:45:50 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Gets a [struct@GioUnix.MountEntry] for a given file path.
|
|
|
|
|
*
|
|
|
|
|
* If @time_read is set, it will be filled with a Unix timestamp for checking
|
|
|
|
|
* if the mounts have changed since with
|
|
|
|
|
* [func@GioUnix.mount_entries_changed_since].
|
2016-09-29 10:45:50 +02:00
|
|
|
|
*
|
2019-03-22 10:51:24 +01:00
|
|
|
|
* If more mounts have the same mount path, the last matching mount
|
|
|
|
|
* is returned.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* This will return `NULL` if looking up the mount entry fails, if
|
2021-06-09 16:53:32 +02:00
|
|
|
|
* @file_path doesn’t exist or there is an I/O error.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full) (nullable): a [struct@GioUnix.MountEntry]
|
2016-09-29 10:45:50 +02:00
|
|
|
|
* Since: 2.52
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.for] instead.
|
2016-09-29 10:45:50 +02:00
|
|
|
|
**/
|
|
|
|
|
GUnixMountEntry *
|
|
|
|
|
g_unix_mount_for (const char *file_path,
|
|
|
|
|
guint64 *time_read)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_for (file_path, time_read);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_for:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @file_path: (type filename): file path on some Unix mount
|
|
|
|
|
* @time_read: (out) (optional): return location for a timestamp
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Gets a [struct@GioUnix.MountEntry] for a given file path.
|
|
|
|
|
*
|
|
|
|
|
* If @time_read is set, it will be filled with a Unix timestamp for checking
|
|
|
|
|
* if the mounts have changed since with
|
|
|
|
|
* [func@GioUnix.mount_entries_changed_since].
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
|
|
|
|
* If more mounts have the same mount path, the last matching mount
|
|
|
|
|
* is returned.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* This will return `NULL` if looking up the mount entry fails, if
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* @file_path doesn’t exist or there is an I/O error.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full) (nullable): a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
**/
|
|
|
|
|
GUnixMountEntry *
|
|
|
|
|
g_unix_mount_entry_for (const char *file_path,
|
|
|
|
|
guint64 *time_read)
|
2016-09-29 10:45:50 +02:00
|
|
|
|
{
|
|
|
|
|
GUnixMountEntry *entry;
|
|
|
|
|
|
|
|
|
|
g_return_val_if_fail (file_path != NULL, NULL);
|
|
|
|
|
|
2024-10-18 11:31:12 +02:00
|
|
|
|
entry = g_unix_mount_entry_at (file_path, time_read);
|
2016-09-29 10:45:50 +02:00
|
|
|
|
if (entry == NULL)
|
|
|
|
|
{
|
|
|
|
|
char *topdir;
|
|
|
|
|
|
|
|
|
|
topdir = _g_local_file_find_topdir_for (file_path);
|
2016-10-24 20:13:22 +02:00
|
|
|
|
if (topdir != NULL)
|
|
|
|
|
{
|
2024-10-18 11:31:12 +02:00
|
|
|
|
entry = g_unix_mount_entry_at (topdir, time_read);
|
2016-10-24 20:13:22 +02:00
|
|
|
|
g_free (topdir);
|
|
|
|
|
}
|
2016-09-29 10:45:50 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return entry;
|
|
|
|
|
}
|
|
|
|
|
|
2022-02-16 11:53:40 +01:00
|
|
|
|
static gpointer
|
|
|
|
|
copy_mount_point_cb (gconstpointer src,
|
|
|
|
|
gpointer data)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountPoint *src_mount_point = (GUnixMountPoint *) src;
|
|
|
|
|
return g_unix_mount_point_copy (src_mount_point);
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/**
|
2017-03-23 12:46:56 +01:00
|
|
|
|
* g_unix_mount_points_get:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @time_read: (out) (optional): return location for a timestamp
|
|
|
|
|
*
|
|
|
|
|
* Gets a list of [struct@GioUnix.MountPoint] instances representing the Unix
|
|
|
|
|
* mount points.
|
2010-06-16 03:57:57 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* If @time_read is set, it will be filled with the mount timestamp, allowing
|
|
|
|
|
* for checking if the mounts have changed with
|
|
|
|
|
* [func@GioUnix.mount_points_changed_since].
|
2010-06-16 03:57:57 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (element-type GUnixMountPoint) (transfer full): a list of the Unix
|
|
|
|
|
* mount points
|
2007-11-26 17:13:05 +01:00
|
|
|
|
**/
|
|
|
|
|
GList *
|
2007-12-17 15:59:23 +01:00
|
|
|
|
g_unix_mount_points_get (guint64 *time_read)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
2022-02-16 11:53:40 +01:00
|
|
|
|
static GList *mnt_pts_last = NULL;
|
|
|
|
|
static guint64 time_read_last = 0;
|
|
|
|
|
GList *mnt_pts = NULL;
|
|
|
|
|
guint64 time_read_now;
|
|
|
|
|
G_LOCK_DEFINE_STATIC (unix_mount_points);
|
|
|
|
|
|
|
|
|
|
G_LOCK (unix_mount_points);
|
|
|
|
|
|
|
|
|
|
time_read_now = get_mount_points_timestamp ();
|
|
|
|
|
if (time_read_now != time_read_last || mnt_pts_last == NULL)
|
|
|
|
|
{
|
|
|
|
|
time_read_last = time_read_now;
|
|
|
|
|
g_list_free_full (mnt_pts_last, (GDestroyNotify) g_unix_mount_point_free);
|
|
|
|
|
mnt_pts_last = _g_get_unix_mount_points ();
|
|
|
|
|
}
|
|
|
|
|
mnt_pts = g_list_copy_deep (mnt_pts_last, copy_mount_point_cb, NULL);
|
|
|
|
|
|
|
|
|
|
G_UNLOCK (unix_mount_points);
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (time_read)
|
2022-02-16 11:53:40 +01:00
|
|
|
|
*time_read = time_read_now;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2022-02-16 11:53:40 +01:00
|
|
|
|
return mnt_pts;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
2024-07-20 14:53:57 +02:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_points_get_from_file:
|
|
|
|
|
* @table_path: path to the mount points table file (for example `/etc/fstab`)
|
|
|
|
|
* @time_read_out: (optional) (out caller-allocates): return location for the
|
|
|
|
|
* modification time of @table_path
|
|
|
|
|
* @n_points_out: (optional) (out caller-allocates): return location for the
|
|
|
|
|
* number of mount points returned
|
|
|
|
|
*
|
|
|
|
|
* Gets an array of [struct@Gio.UnixMountPoint]s containing the Unix mount
|
|
|
|
|
* points listed in @table_path.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* This is a generalized version of [func@GioUnix.mount_points_get], mainly
|
|
|
|
|
* intended for internal testing use. Note that [func@GioUnix.mount_points_get]
|
|
|
|
|
* may parse multiple hierarchical table files, so this function is not a direct
|
|
|
|
|
* superset of its functionality.
|
2024-07-20 14:53:57 +02:00
|
|
|
|
*
|
|
|
|
|
* If there is an error reading or parsing the file, `NULL` will be returned
|
|
|
|
|
* and both out parameters will be set to `0`.
|
|
|
|
|
*
|
|
|
|
|
* Returns: (transfer full) (array length=n_points_out) (nullable): mount
|
|
|
|
|
* points, or `NULL` if there was an error loading them
|
|
|
|
|
* Since: 2.82
|
|
|
|
|
*/
|
|
|
|
|
GUnixMountPoint **
|
|
|
|
|
g_unix_mount_points_get_from_file (const char *table_path,
|
|
|
|
|
uint64_t *time_read_out,
|
|
|
|
|
size_t *n_points_out)
|
|
|
|
|
{
|
|
|
|
|
return _g_unix_mount_points_get_from_file (table_path, time_read_out, n_points_out);
|
|
|
|
|
}
|
|
|
|
|
|
2020-06-23 08:23:16 +02:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_at:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_path: (type filename): path for a possible Unix mount point
|
|
|
|
|
* @time_read: (out) (optional): return location for a timestamp
|
2020-06-23 08:23:16 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Gets a [struct@GioUnix.MountPoint] for a given mount path.
|
|
|
|
|
*
|
|
|
|
|
* If @time_read is set, it will be filled with a Unix timestamp for checking if
|
|
|
|
|
* the mount points have changed since with
|
|
|
|
|
* [func@GioUnix.mount_points_changed_since].
|
2020-06-23 08:23:16 +02:00
|
|
|
|
*
|
|
|
|
|
* If more mount points have the same mount path, the last matching mount point
|
|
|
|
|
* is returned.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full) (nullable): a [struct@GioUnix.MountPoint], or `NULL`
|
|
|
|
|
* if no match is found
|
2020-06-23 08:23:16 +02:00
|
|
|
|
* Since: 2.66
|
|
|
|
|
**/
|
|
|
|
|
GUnixMountPoint *
|
|
|
|
|
g_unix_mount_point_at (const char *mount_path,
|
|
|
|
|
guint64 *time_read)
|
|
|
|
|
{
|
|
|
|
|
GList *mount_points, *l;
|
|
|
|
|
GUnixMountPoint *mount_point, *found;
|
|
|
|
|
|
|
|
|
|
mount_points = g_unix_mount_points_get (time_read);
|
|
|
|
|
|
|
|
|
|
found = NULL;
|
|
|
|
|
for (l = mount_points; l != NULL; l = l->next)
|
|
|
|
|
{
|
|
|
|
|
mount_point = l->data;
|
|
|
|
|
|
|
|
|
|
if (strcmp (mount_path, mount_point->mount_path) == 0)
|
|
|
|
|
{
|
|
|
|
|
if (found != NULL)
|
|
|
|
|
g_unix_mount_point_free (found);
|
|
|
|
|
|
|
|
|
|
found = mount_point;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
g_unix_mount_point_free (mount_point);
|
|
|
|
|
}
|
|
|
|
|
g_list_free (mount_points);
|
|
|
|
|
|
|
|
|
|
return found;
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/**
|
2007-11-27 15:00:13 +01:00
|
|
|
|
* g_unix_mounts_changed_since:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @time: a timestamp
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Checks if the Unix mounts have changed since a given Unix time.
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if the mounts have changed since @time; false otherwise
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.mount_entries_changed_since] instead.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
**/
|
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mounts_changed_since (guint64 time)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entries_changed_since (time);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entries_changed_since:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @time: a timestamp
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Checks if the Unix mounts have changed since a given Unix time.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 13:34:12 +01:00
|
|
|
|
* This can only work reliably if a [class@GioUnix.MountMonitor] is running in
|
|
|
|
|
* the process, otherwise changes in the mount entries file (such as
|
|
|
|
|
* `/proc/self/mountinfo` on Linux) cannot be detected and, as a result, this
|
|
|
|
|
* function has to conservatively always return `TRUE`.
|
|
|
|
|
*
|
|
|
|
|
* It is more efficient to use [signal@GioUnix.MountMonitor::mounts-changed] to
|
|
|
|
|
* be signalled of changes to the mount entries, rather than polling using this
|
|
|
|
|
* function. This function is more appropriate for infrequently determining
|
|
|
|
|
* cache validity.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if the mounts have changed since @time; false otherwise
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since 2.84
|
|
|
|
|
**/
|
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_entries_changed_since (guint64 time)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
return get_mounts_timestamp () != time;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2007-11-27 15:00:13 +01:00
|
|
|
|
* g_unix_mount_points_changed_since:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @time: a timestamp
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Checks if the Unix mount points have changed since a given Unix time.
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 13:34:12 +01:00
|
|
|
|
* Unlike [func@GioUnix.mount_entries_changed_since], this function can work
|
|
|
|
|
* reliably without a [class@GioUnix.MountMonitor] running, as it accesses the
|
|
|
|
|
* static mount point information (such as `/etc/fstab` on Linux), which has a
|
|
|
|
|
* valid modification time.
|
|
|
|
|
*
|
|
|
|
|
* It is more efficient to use [signal@GioUnix.MountMonitor::mountpoints-changed]
|
|
|
|
|
* to be signalled of changes to the mount points, rather than polling using
|
|
|
|
|
* this function. This function is more appropriate for infrequently determining
|
|
|
|
|
* cache validity.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if the mount points have changed since @time; false otherwise
|
2007-11-26 17:13:05 +01:00
|
|
|
|
**/
|
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_points_changed_since (guint64 time)
|
|
|
|
|
{
|
|
|
|
|
return get_mount_points_timestamp () != time;
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* GUnixMountMonitor {{{1 */
|
|
|
|
|
|
2015-01-08 05:52:53 +01:00
|
|
|
|
enum {
|
|
|
|
|
MOUNTS_CHANGED,
|
|
|
|
|
MOUNTPOINTS_CHANGED,
|
|
|
|
|
LAST_SIGNAL
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
static guint signals[LAST_SIGNAL];
|
|
|
|
|
|
|
|
|
|
struct _GUnixMountMonitor {
|
|
|
|
|
GObject parent;
|
|
|
|
|
|
2015-01-08 07:35:33 +01:00
|
|
|
|
GMainContext *context;
|
2015-01-08 05:52:53 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct _GUnixMountMonitorClass {
|
|
|
|
|
GObjectClass parent_class;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
2014-10-17 12:54:02 +02:00
|
|
|
|
G_DEFINE_TYPE (GUnixMountMonitor, g_unix_mount_monitor, G_TYPE_OBJECT)
|
2015-01-08 05:52:53 +01:00
|
|
|
|
|
2015-01-08 07:35:33 +01:00
|
|
|
|
static GContextSpecificGroup mount_monitor_group;
|
|
|
|
|
static GFileMonitor *fstab_monitor;
|
|
|
|
|
static GFileMonitor *mtab_monitor;
|
|
|
|
|
static GList *mount_poller_mounts;
|
2018-01-15 17:56:26 +01:00
|
|
|
|
static guint mtab_file_changed_id;
|
2007-11-26 17:13:05 +01:00
|
|
|
|
|
2020-02-10 16:00:42 +01:00
|
|
|
|
/* Called with proc_mounts_source lock held. */
|
2017-09-08 18:42:14 +02:00
|
|
|
|
static gboolean
|
|
|
|
|
proc_mounts_watch_is_running (void)
|
|
|
|
|
{
|
|
|
|
|
return proc_mounts_watch_source != NULL &&
|
|
|
|
|
!g_source_is_destroyed (proc_mounts_watch_source);
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
static void
|
2007-11-30 06:11:25 +01:00
|
|
|
|
fstab_file_changed (GFileMonitor *monitor,
|
2015-01-08 07:35:33 +01:00
|
|
|
|
GFile *file,
|
|
|
|
|
GFile *other_file,
|
|
|
|
|
GFileMonitorEvent event_type,
|
|
|
|
|
gpointer user_data)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
if (event_type != G_FILE_MONITOR_EVENT_CHANGED &&
|
|
|
|
|
event_type != G_FILE_MONITOR_EVENT_CREATED &&
|
|
|
|
|
event_type != G_FILE_MONITOR_EVENT_DELETED)
|
|
|
|
|
return;
|
|
|
|
|
|
2015-01-08 07:35:33 +01:00
|
|
|
|
g_context_specific_group_emit (&mount_monitor_group, signals[MOUNTPOINTS_CHANGED]);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
2018-01-15 17:56:26 +01:00
|
|
|
|
static gboolean
|
|
|
|
|
mtab_file_changed_cb (gpointer user_data)
|
|
|
|
|
{
|
|
|
|
|
mtab_file_changed_id = 0;
|
|
|
|
|
g_context_specific_group_emit (&mount_monitor_group, signals[MOUNTS_CHANGED]);
|
|
|
|
|
|
|
|
|
|
return G_SOURCE_REMOVE;
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
static void
|
2007-11-30 06:11:25 +01:00
|
|
|
|
mtab_file_changed (GFileMonitor *monitor,
|
2015-01-08 07:35:33 +01:00
|
|
|
|
GFile *file,
|
|
|
|
|
GFile *other_file,
|
|
|
|
|
GFileMonitorEvent event_type,
|
|
|
|
|
gpointer user_data)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
2020-02-17 11:05:07 +01:00
|
|
|
|
GMainContext *context;
|
|
|
|
|
GSource *source;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (event_type != G_FILE_MONITOR_EVENT_CHANGED &&
|
|
|
|
|
event_type != G_FILE_MONITOR_EVENT_CREATED &&
|
|
|
|
|
event_type != G_FILE_MONITOR_EVENT_DELETED)
|
|
|
|
|
return;
|
2015-01-08 07:35:33 +01:00
|
|
|
|
|
2018-01-15 17:56:26 +01:00
|
|
|
|
/* Skip accumulated events from file monitor which we are not able to handle
|
|
|
|
|
* in a real time instead of emitting mounts_changed signal several times.
|
|
|
|
|
* This should behave equally to GIOChannel based monitoring. See Bug 792235.
|
|
|
|
|
*/
|
|
|
|
|
if (mtab_file_changed_id > 0)
|
|
|
|
|
return;
|
|
|
|
|
|
2020-02-17 11:05:07 +01:00
|
|
|
|
context = g_main_context_get_thread_default ();
|
|
|
|
|
if (!context)
|
|
|
|
|
context = g_main_context_default ();
|
|
|
|
|
|
|
|
|
|
source = g_idle_source_new ();
|
|
|
|
|
g_source_set_priority (source, G_PRIORITY_DEFAULT);
|
|
|
|
|
g_source_set_callback (source, mtab_file_changed_cb, NULL, NULL);
|
2021-07-26 11:53:02 +02:00
|
|
|
|
g_source_set_static_name (source, "[gio] mtab_file_changed_cb");
|
2020-02-17 11:05:07 +01:00
|
|
|
|
g_source_attach (source, context);
|
|
|
|
|
g_source_unref (source);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
2011-09-29 21:09:43 +02:00
|
|
|
|
static gboolean
|
|
|
|
|
proc_mounts_changed (GIOChannel *channel,
|
|
|
|
|
GIOCondition cond,
|
|
|
|
|
gpointer user_data)
|
|
|
|
|
{
|
2024-01-22 15:29:37 +01:00
|
|
|
|
gboolean has_changed = FALSE;
|
|
|
|
|
|
|
|
|
|
#ifdef HAVE_LIBMOUNT
|
|
|
|
|
if (cond & G_IO_IN)
|
|
|
|
|
{
|
|
|
|
|
G_LOCK (proc_mounts_source);
|
|
|
|
|
if (proc_mounts_monitor != NULL)
|
|
|
|
|
{
|
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
|
|
/* The mnt_monitor_next_change function needs to be used to avoid false-positives. */
|
|
|
|
|
ret = mnt_monitor_next_change (proc_mounts_monitor, NULL, NULL);
|
|
|
|
|
if (ret == 0)
|
|
|
|
|
{
|
|
|
|
|
has_changed = TRUE;
|
|
|
|
|
ret = mnt_monitor_event_cleanup (proc_mounts_monitor);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (ret < 0)
|
|
|
|
|
g_debug ("mnt_monitor_next_change failed: %s", g_strerror (-ret));
|
|
|
|
|
}
|
|
|
|
|
G_UNLOCK (proc_mounts_source);
|
|
|
|
|
}
|
2024-04-19 09:54:50 +02:00
|
|
|
|
#endif
|
2024-01-22 15:29:37 +01:00
|
|
|
|
|
2011-09-29 21:49:09 +02:00
|
|
|
|
if (cond & G_IO_ERR)
|
2024-01-22 15:29:37 +01:00
|
|
|
|
has_changed = TRUE;
|
|
|
|
|
|
|
|
|
|
if (has_changed)
|
2017-09-08 18:42:14 +02:00
|
|
|
|
{
|
2020-02-10 16:00:42 +01:00
|
|
|
|
G_LOCK (proc_mounts_source);
|
2017-09-08 18:42:14 +02:00
|
|
|
|
mount_poller_time = (guint64) g_get_monotonic_time ();
|
2020-02-10 16:00:42 +01:00
|
|
|
|
G_UNLOCK (proc_mounts_source);
|
|
|
|
|
|
2017-09-08 18:42:14 +02:00
|
|
|
|
g_context_specific_group_emit (&mount_monitor_group, signals[MOUNTS_CHANGED]);
|
|
|
|
|
}
|
2015-01-08 07:35:33 +01:00
|
|
|
|
|
2011-09-29 21:09:43 +02:00
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
2014-08-18 22:48:28 +02:00
|
|
|
|
static gboolean
|
|
|
|
|
mount_change_poller (gpointer user_data)
|
|
|
|
|
{
|
2014-08-26 18:27:23 +02:00
|
|
|
|
GList *current_mounts, *new_it, *old_it;
|
2014-08-18 22:48:28 +02:00
|
|
|
|
gboolean has_changed = FALSE;
|
|
|
|
|
|
|
|
|
|
current_mounts = _g_get_unix_mounts ();
|
|
|
|
|
|
2015-01-08 07:35:33 +01:00
|
|
|
|
for ( new_it = current_mounts, old_it = mount_poller_mounts;
|
2014-08-26 18:27:23 +02:00
|
|
|
|
new_it != NULL && old_it != NULL;
|
|
|
|
|
new_it = g_list_next (new_it), old_it = g_list_next (old_it) )
|
2014-08-18 22:48:28 +02:00
|
|
|
|
{
|
2024-10-18 11:31:12 +02:00
|
|
|
|
if (g_unix_mount_entry_compare (new_it->data, old_it->data) != 0)
|
2014-08-18 22:48:28 +02:00
|
|
|
|
{
|
2014-08-26 18:27:23 +02:00
|
|
|
|
has_changed = TRUE;
|
|
|
|
|
break;
|
2014-08-18 22:48:28 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2014-08-26 18:27:23 +02:00
|
|
|
|
if (!(new_it == NULL && old_it == NULL))
|
|
|
|
|
has_changed = TRUE;
|
|
|
|
|
|
2024-10-18 11:31:12 +02:00
|
|
|
|
g_list_free_full (mount_poller_mounts, (GDestroyNotify) g_unix_mount_entry_free);
|
2014-08-18 22:48:28 +02:00
|
|
|
|
|
2015-01-08 07:35:33 +01:00
|
|
|
|
mount_poller_mounts = current_mounts;
|
2014-08-18 22:48:28 +02:00
|
|
|
|
|
|
|
|
|
if (has_changed)
|
|
|
|
|
{
|
2020-02-10 16:00:42 +01:00
|
|
|
|
G_LOCK (proc_mounts_source);
|
2015-01-08 07:35:33 +01:00
|
|
|
|
mount_poller_time = (guint64) g_get_monotonic_time ();
|
2020-02-10 16:00:42 +01:00
|
|
|
|
G_UNLOCK (proc_mounts_source);
|
|
|
|
|
|
2015-01-08 07:35:33 +01:00
|
|
|
|
g_context_specific_group_emit (&mount_monitor_group, signals[MOUNTPOINTS_CHANGED]);
|
2014-08-18 22:48:28 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 07:35:33 +01:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
static void
|
2015-01-08 07:35:33 +01:00
|
|
|
|
mount_monitor_stop (void)
|
|
|
|
|
{
|
|
|
|
|
if (fstab_monitor)
|
|
|
|
|
{
|
|
|
|
|
g_file_monitor_cancel (fstab_monitor);
|
|
|
|
|
g_object_unref (fstab_monitor);
|
|
|
|
|
}
|
|
|
|
|
|
2020-02-10 16:00:42 +01:00
|
|
|
|
G_LOCK (proc_mounts_source);
|
2015-01-08 07:35:33 +01:00
|
|
|
|
if (proc_mounts_watch_source != NULL)
|
2017-09-08 18:42:14 +02:00
|
|
|
|
{
|
|
|
|
|
g_source_destroy (proc_mounts_watch_source);
|
|
|
|
|
proc_mounts_watch_source = NULL;
|
|
|
|
|
}
|
2024-01-22 15:29:37 +01:00
|
|
|
|
|
|
|
|
|
#ifdef HAVE_LIBMOUNT
|
|
|
|
|
g_clear_pointer (&proc_mounts_monitor, mnt_unref_monitor);
|
|
|
|
|
#endif
|
2020-02-10 16:00:42 +01:00
|
|
|
|
G_UNLOCK (proc_mounts_source);
|
2015-01-08 07:35:33 +01:00
|
|
|
|
|
|
|
|
|
if (mtab_monitor)
|
|
|
|
|
{
|
|
|
|
|
g_file_monitor_cancel (mtab_monitor);
|
|
|
|
|
g_object_unref (mtab_monitor);
|
|
|
|
|
}
|
|
|
|
|
|
2020-02-17 11:20:17 +01:00
|
|
|
|
if (mtab_file_changed_id)
|
|
|
|
|
{
|
|
|
|
|
g_source_remove (mtab_file_changed_id);
|
|
|
|
|
mtab_file_changed_id = 0;
|
|
|
|
|
}
|
|
|
|
|
|
2024-10-18 11:31:12 +02:00
|
|
|
|
g_list_free_full (mount_poller_mounts, (GDestroyNotify) g_unix_mount_entry_free);
|
2015-01-08 07:35:33 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
mount_monitor_start (void)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
GFile *file;
|
2015-01-08 07:35:33 +01:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (get_fstab_file () != NULL)
|
|
|
|
|
{
|
|
|
|
|
file = g_file_new_for_path (get_fstab_file ());
|
2015-01-08 07:35:33 +01:00
|
|
|
|
fstab_monitor = g_file_monitor_file (file, 0, NULL, NULL);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
g_object_unref (file);
|
2015-01-08 07:35:33 +01:00
|
|
|
|
|
|
|
|
|
g_signal_connect (fstab_monitor, "changed", (GCallback)fstab_file_changed, NULL);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
2015-01-08 07:35:33 +01:00
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (get_mtab_monitor_file () != NULL)
|
|
|
|
|
{
|
2011-09-29 21:09:43 +02:00
|
|
|
|
const gchar *mtab_path;
|
|
|
|
|
|
|
|
|
|
mtab_path = get_mtab_monitor_file ();
|
2016-09-27 10:32:04 +02:00
|
|
|
|
/* Monitoring files in /proc/ is special - can't just use GFileMonitor.
|
2011-09-29 21:49:09 +02:00
|
|
|
|
* See 'man proc' for more details.
|
|
|
|
|
*/
|
2016-09-27 10:32:04 +02:00
|
|
|
|
if (g_str_has_prefix (mtab_path, "/proc/"))
|
2011-09-29 21:09:43 +02:00
|
|
|
|
{
|
2024-01-22 15:29:37 +01:00
|
|
|
|
GIOChannel *proc_mounts_channel = NULL;
|
2011-09-29 21:49:09 +02:00
|
|
|
|
GError *error = NULL;
|
2024-01-22 15:29:37 +01:00
|
|
|
|
#ifdef HAVE_LIBMOUNT
|
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
|
|
G_LOCK (proc_mounts_source);
|
|
|
|
|
|
|
|
|
|
proc_mounts_monitor = mnt_new_monitor ();
|
|
|
|
|
ret = mnt_monitor_enable_kernel (proc_mounts_monitor, TRUE);
|
|
|
|
|
if (ret < 0)
|
|
|
|
|
g_warning ("mnt_monitor_enable_kernel failed: %s", g_strerror (-ret));
|
|
|
|
|
|
|
|
|
|
ret = mnt_monitor_enable_userspace (proc_mounts_monitor, TRUE, NULL);
|
|
|
|
|
if (ret < 0)
|
|
|
|
|
g_warning ("mnt_monitor_enable_userspace failed: %s", g_strerror (-ret));
|
|
|
|
|
|
2024-01-31 13:35:39 +01:00
|
|
|
|
#ifdef HAVE_MNT_MONITOR_VEIL_KERNEL
|
|
|
|
|
ret = mnt_monitor_veil_kernel (proc_mounts_monitor, TRUE);
|
|
|
|
|
if (ret < 0)
|
|
|
|
|
g_warning ("mnt_monitor_veil_kernel failed: %s", g_strerror (-ret));
|
|
|
|
|
#endif
|
|
|
|
|
|
2024-01-22 15:29:37 +01:00
|
|
|
|
ret = mnt_monitor_get_fd (proc_mounts_monitor);
|
|
|
|
|
if (ret >= 0)
|
|
|
|
|
{
|
|
|
|
|
proc_mounts_channel = g_io_channel_unix_new (ret);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2024-04-19 09:54:50 +02:00
|
|
|
|
g_debug ("mnt_monitor_get_fd failed: %s", g_strerror (-ret));
|
|
|
|
|
g_clear_pointer (&proc_mounts_monitor, mnt_unref_monitor);
|
|
|
|
|
|
|
|
|
|
/* The mnt_monitor_get_fd function failed e.g. inotify limits are
|
|
|
|
|
* exceeded. Let's try to silently fallback to the old behavior.
|
|
|
|
|
* See: https://gitlab.gnome.org/GNOME/tracker-miners/-/issues/315
|
|
|
|
|
*/
|
2024-01-22 15:29:37 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
G_UNLOCK (proc_mounts_source);
|
|
|
|
|
#endif
|
2024-04-19 09:54:50 +02:00
|
|
|
|
if (proc_mounts_channel == NULL)
|
|
|
|
|
proc_mounts_channel = g_io_channel_new_file (mtab_path, "r", &error);
|
|
|
|
|
|
2024-04-10 01:13:01 +02:00
|
|
|
|
if (error != NULL)
|
2011-09-29 21:49:09 +02:00
|
|
|
|
{
|
2016-09-27 10:32:04 +02:00
|
|
|
|
g_warning ("Error creating IO channel for %s: %s (%s, %d)", mtab_path,
|
2011-09-29 21:49:09 +02:00
|
|
|
|
error->message, g_quark_to_string (error->domain), error->code);
|
|
|
|
|
g_error_free (error);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2020-02-10 16:00:42 +01:00
|
|
|
|
G_LOCK (proc_mounts_source);
|
|
|
|
|
|
2024-01-22 15:29:37 +01:00
|
|
|
|
#ifdef HAVE_LIBMOUNT
|
2024-04-19 09:54:50 +02:00
|
|
|
|
if (proc_mounts_monitor != NULL)
|
|
|
|
|
proc_mounts_watch_source = g_io_create_watch (proc_mounts_channel, G_IO_IN);
|
2024-01-22 15:29:37 +01:00
|
|
|
|
#endif
|
2024-04-19 09:54:50 +02:00
|
|
|
|
if (proc_mounts_watch_source == NULL)
|
|
|
|
|
proc_mounts_watch_source = g_io_create_watch (proc_mounts_channel, G_IO_ERR);
|
|
|
|
|
|
2020-02-18 09:10:03 +01:00
|
|
|
|
mount_poller_time = (guint64) g_get_monotonic_time ();
|
2015-01-08 07:35:33 +01:00
|
|
|
|
g_source_set_callback (proc_mounts_watch_source,
|
2011-09-29 21:49:09 +02:00
|
|
|
|
(GSourceFunc) proc_mounts_changed,
|
2015-01-08 07:35:33 +01:00
|
|
|
|
NULL, NULL);
|
|
|
|
|
g_source_attach (proc_mounts_watch_source,
|
2011-09-29 21:49:09 +02:00
|
|
|
|
g_main_context_get_thread_default ());
|
2015-01-08 07:35:33 +01:00
|
|
|
|
g_source_unref (proc_mounts_watch_source);
|
2011-09-29 21:49:09 +02:00
|
|
|
|
g_io_channel_unref (proc_mounts_channel);
|
2020-02-10 16:00:42 +01:00
|
|
|
|
|
|
|
|
|
G_UNLOCK (proc_mounts_source);
|
2011-09-29 21:49:09 +02:00
|
|
|
|
}
|
2011-09-29 21:09:43 +02:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2011-09-29 21:49:09 +02:00
|
|
|
|
file = g_file_new_for_path (mtab_path);
|
2015-01-08 07:35:33 +01:00
|
|
|
|
mtab_monitor = g_file_monitor_file (file, 0, NULL, NULL);
|
2011-09-29 21:09:43 +02:00
|
|
|
|
g_object_unref (file);
|
2015-01-08 07:35:33 +01:00
|
|
|
|
g_signal_connect (mtab_monitor, "changed", (GCallback)mtab_file_changed, NULL);
|
2011-09-29 21:09:43 +02:00
|
|
|
|
}
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
2014-08-18 22:48:28 +02:00
|
|
|
|
else
|
|
|
|
|
{
|
2020-02-10 16:00:42 +01:00
|
|
|
|
G_LOCK (proc_mounts_source);
|
|
|
|
|
|
2015-01-08 07:35:33 +01:00
|
|
|
|
proc_mounts_watch_source = g_timeout_source_new_seconds (3);
|
|
|
|
|
mount_poller_mounts = _g_get_unix_mounts ();
|
2014-08-26 18:27:23 +02:00
|
|
|
|
mount_poller_time = (guint64)g_get_monotonic_time ();
|
2015-01-08 07:35:33 +01:00
|
|
|
|
g_source_set_callback (proc_mounts_watch_source,
|
|
|
|
|
mount_change_poller,
|
|
|
|
|
NULL, NULL);
|
|
|
|
|
g_source_attach (proc_mounts_watch_source,
|
2014-08-18 22:48:28 +02:00
|
|
|
|
g_main_context_get_thread_default ());
|
2015-01-08 07:35:33 +01:00
|
|
|
|
g_source_unref (proc_mounts_watch_source);
|
2020-02-10 16:00:42 +01:00
|
|
|
|
|
|
|
|
|
G_UNLOCK (proc_mounts_source);
|
2014-08-18 22:48:28 +02:00
|
|
|
|
}
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 07:35:33 +01:00
|
|
|
|
static void
|
|
|
|
|
g_unix_mount_monitor_finalize (GObject *object)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountMonitor *monitor;
|
|
|
|
|
|
|
|
|
|
monitor = G_UNIX_MOUNT_MONITOR (object);
|
|
|
|
|
|
|
|
|
|
g_context_specific_group_remove (&mount_monitor_group, monitor->context, monitor, mount_monitor_stop);
|
|
|
|
|
|
|
|
|
|
G_OBJECT_CLASS (g_unix_mount_monitor_parent_class)->finalize (object);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
g_unix_mount_monitor_class_init (GUnixMountMonitorClass *klass)
|
|
|
|
|
{
|
|
|
|
|
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
|
|
|
|
|
|
|
|
|
|
gobject_class->finalize = g_unix_mount_monitor_finalize;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* GUnixMountMonitor::mounts-changed:
|
|
|
|
|
* @monitor: the object on which the signal is emitted
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Emitted when the Unix mount entries have changed.
|
2015-01-08 07:35:33 +01:00
|
|
|
|
*/
|
|
|
|
|
signals[MOUNTS_CHANGED] =
|
2015-09-12 06:00:40 +02:00
|
|
|
|
g_signal_new (I_("mounts-changed"),
|
2015-01-08 07:35:33 +01:00
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
|
0,
|
|
|
|
|
NULL, NULL,
|
2019-05-31 04:13:37 +02:00
|
|
|
|
NULL,
|
2015-01-08 07:35:33 +01:00
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* GUnixMountMonitor::mountpoints-changed:
|
|
|
|
|
* @monitor: the object on which the signal is emitted
|
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Emitted when the Unix mount points have changed.
|
2015-01-08 07:35:33 +01:00
|
|
|
|
*/
|
|
|
|
|
signals[MOUNTPOINTS_CHANGED] =
|
2015-09-12 06:00:40 +02:00
|
|
|
|
g_signal_new (I_("mountpoints-changed"),
|
2015-01-08 07:35:33 +01:00
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
|
0,
|
|
|
|
|
NULL, NULL,
|
2019-05-31 04:13:37 +02:00
|
|
|
|
NULL,
|
2015-01-08 07:35:33 +01:00
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
g_unix_mount_monitor_init (GUnixMountMonitor *monitor)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2008-03-14 12:18:59 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_monitor_set_rate_limit:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_monitor: a [class@GioUnix.MountMonitor]
|
|
|
|
|
* @limit_msec: a integer with the limit (in milliseconds) to poll for changes
|
2008-03-14 12:18:59 +01:00
|
|
|
|
*
|
2015-01-08 08:16:50 +01:00
|
|
|
|
* This function does nothing.
|
|
|
|
|
*
|
|
|
|
|
* Before 2.44, this was a partially-effective way of controlling the
|
|
|
|
|
* rate at which events would be reported under some uncommon
|
|
|
|
|
* circumstances. Since @mount_monitor is a singleton, it also meant
|
|
|
|
|
* that calling this function would have side effects for other users of
|
|
|
|
|
* the monitor.
|
2008-03-14 12:18:59 +01:00
|
|
|
|
*
|
|
|
|
|
* Since: 2.18
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Deprecated: 2.44: This function does nothing. Don’t call it.
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2008-03-14 12:18:59 +01:00
|
|
|
|
void
|
|
|
|
|
g_unix_mount_monitor_set_rate_limit (GUnixMountMonitor *mount_monitor,
|
2009-01-19 07:09:11 +01:00
|
|
|
|
gint limit_msec)
|
2008-03-14 12:18:59 +01:00
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/**
|
2015-01-08 08:03:18 +01:00
|
|
|
|
* g_unix_mount_monitor_get:
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Gets the [class@GioUnix.MountMonitor] for the current thread-default main
|
2015-01-08 07:35:33 +01:00
|
|
|
|
* context.
|
2015-01-08 08:03:18 +01:00
|
|
|
|
*
|
|
|
|
|
* The mount monitor can be used to monitor for changes to the list of
|
|
|
|
|
* mounted filesystems as well as the list of mount points (ie: fstab
|
|
|
|
|
* entries).
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* You must only call [method@GObject.Object.unref] on the return value from
|
|
|
|
|
* under the same main context as you called this function.
|
2015-01-08 08:03:18 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): the [class@GioUnix.MountMonitor]
|
2015-01-08 08:03:18 +01:00
|
|
|
|
* Since: 2.44
|
|
|
|
|
**/
|
2007-11-26 17:13:05 +01:00
|
|
|
|
GUnixMountMonitor *
|
2015-01-08 08:03:18 +01:00
|
|
|
|
g_unix_mount_monitor_get (void)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
2015-01-08 07:35:33 +01:00
|
|
|
|
return g_context_specific_group_get (&mount_monitor_group,
|
|
|
|
|
G_TYPE_UNIX_MOUNT_MONITOR,
|
|
|
|
|
G_STRUCT_OFFSET(GUnixMountMonitor, context),
|
|
|
|
|
mount_monitor_start);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 08:03:18 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_monitor_new:
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Deprecated alias for [func@GioUnix.MountMonitor.get].
|
2015-01-08 08:03:18 +01:00
|
|
|
|
*
|
|
|
|
|
* This function was never a true constructor, which is why it was
|
|
|
|
|
* renamed.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: a [class@GioUnix.MountMonitor]
|
|
|
|
|
* Deprecated: 2.44: Use [func@GioUnix.MountMonitor.get] instead.
|
2015-01-08 08:03:18 +01:00
|
|
|
|
*/
|
|
|
|
|
GUnixMountMonitor *
|
|
|
|
|
g_unix_mount_monitor_new (void)
|
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_monitor_get ();
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* GUnixMount {{{1 */
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_free:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Frees a Unix mount.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.free] instead.
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2007-11-26 17:13:05 +01:00
|
|
|
|
void
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
g_unix_mount_free (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
g_unix_mount_entry_free (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_free:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Frees a Unix mount.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
void
|
|
|
|
|
g_unix_mount_entry_free (GUnixMountEntry *mount_entry)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
g_return_if_fail (mount_entry != NULL);
|
|
|
|
|
|
|
|
|
|
g_free (mount_entry->mount_path);
|
|
|
|
|
g_free (mount_entry->device_path);
|
2018-04-26 10:37:33 +02:00
|
|
|
|
g_free (mount_entry->root_path);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
g_free (mount_entry->filesystem_type);
|
2018-04-26 10:36:36 +02:00
|
|
|
|
g_free (mount_entry->options);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
g_free (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-23 12:46:56 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_copy:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2017-03-23 12:46:56 +01:00
|
|
|
|
*
|
|
|
|
|
* Makes a copy of @mount_entry.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a new [struct@GioUnix.MountEntry]
|
2017-03-23 12:46:56 +01:00
|
|
|
|
* Since: 2.54
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.copy] instead.
|
2017-03-23 12:46:56 +01:00
|
|
|
|
*/
|
|
|
|
|
GUnixMountEntry *
|
|
|
|
|
g_unix_mount_copy (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_copy (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_copy:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
|
|
|
|
* Makes a copy of @mount_entry.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a new [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
GUnixMountEntry *
|
|
|
|
|
g_unix_mount_entry_copy (GUnixMountEntry *mount_entry)
|
2017-03-23 12:46:56 +01:00
|
|
|
|
{
|
|
|
|
|
GUnixMountEntry *copy;
|
|
|
|
|
|
|
|
|
|
g_return_val_if_fail (mount_entry != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
copy = g_new0 (GUnixMountEntry, 1);
|
|
|
|
|
copy->mount_path = g_strdup (mount_entry->mount_path);
|
|
|
|
|
copy->device_path = g_strdup (mount_entry->device_path);
|
2018-04-26 10:37:33 +02:00
|
|
|
|
copy->root_path = g_strdup (mount_entry->root_path);
|
2017-03-23 12:46:56 +01:00
|
|
|
|
copy->filesystem_type = g_strdup (mount_entry->filesystem_type);
|
2018-04-26 10:36:36 +02:00
|
|
|
|
copy->options = g_strdup (mount_entry->options);
|
2017-03-23 12:46:56 +01:00
|
|
|
|
copy->is_read_only = mount_entry->is_read_only;
|
|
|
|
|
copy->is_system_internal = mount_entry->is_system_internal;
|
|
|
|
|
|
|
|
|
|
return copy;
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_free:
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* @mount_point: Unix mount point to free.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Frees a Unix mount point.
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2007-11-26 17:13:05 +01:00
|
|
|
|
void
|
|
|
|
|
g_unix_mount_point_free (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
g_return_if_fail (mount_point != NULL);
|
|
|
|
|
|
|
|
|
|
g_free (mount_point->mount_path);
|
|
|
|
|
g_free (mount_point->device_path);
|
|
|
|
|
g_free (mount_point->filesystem_type);
|
2011-09-30 05:46:28 +02:00
|
|
|
|
g_free (mount_point->options);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
g_free (mount_point);
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-23 12:46:56 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_copy:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2017-03-23 12:46:56 +01:00
|
|
|
|
*
|
|
|
|
|
* Makes a copy of @mount_point.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a new [struct@GioUnix.MountPoint]
|
2017-03-23 12:46:56 +01:00
|
|
|
|
* Since: 2.54
|
|
|
|
|
*/
|
|
|
|
|
GUnixMountPoint*
|
|
|
|
|
g_unix_mount_point_copy (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountPoint *copy;
|
|
|
|
|
|
|
|
|
|
g_return_val_if_fail (mount_point != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
copy = g_new0 (GUnixMountPoint, 1);
|
|
|
|
|
copy->mount_path = g_strdup (mount_point->mount_path);
|
|
|
|
|
copy->device_path = g_strdup (mount_point->device_path);
|
|
|
|
|
copy->filesystem_type = g_strdup (mount_point->filesystem_type);
|
|
|
|
|
copy->options = g_strdup (mount_point->options);
|
|
|
|
|
copy->is_read_only = mount_point->is_read_only;
|
|
|
|
|
copy->is_user_mountable = mount_point->is_user_mountable;
|
|
|
|
|
copy->is_loopback = mount_point->is_loopback;
|
|
|
|
|
|
|
|
|
|
return copy;
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_compare:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount1: first [struct@GioUnix.MountEntry] to compare
|
|
|
|
|
* @mount2: second [struct@GioUnix.MountEntry] to compare
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Compares two Unix mounts.
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: `1`, `0` or `-1` if @mount1 is greater than, equal to,
|
|
|
|
|
* or less than @mount2, respectively
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.compare] instead.
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2007-11-26 17:13:05 +01:00
|
|
|
|
gint
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
g_unix_mount_compare (GUnixMountEntry *mount1,
|
|
|
|
|
GUnixMountEntry *mount2)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_compare (mount1, mount2);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_compare:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount1: first [struct@GioUnix.MountEntry] to compare
|
|
|
|
|
* @mount2: second [struct@GioUnix.MountEntry] to compare
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Compares two Unix mounts.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: `1`, `0` or `-1` if @mount1 is greater than, equal to,
|
|
|
|
|
* or less than @mount2, respectively
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
gint
|
|
|
|
|
g_unix_mount_entry_compare (GUnixMountEntry *mount1,
|
|
|
|
|
GUnixMountEntry *mount2)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
int res;
|
|
|
|
|
|
|
|
|
|
g_return_val_if_fail (mount1 != NULL && mount2 != NULL, 0);
|
|
|
|
|
|
2008-07-15 07:42:11 +02:00
|
|
|
|
res = g_strcmp0 (mount1->mount_path, mount2->mount_path);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
2008-07-15 07:42:11 +02:00
|
|
|
|
res = g_strcmp0 (mount1->device_path, mount2->device_path);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
2018-04-26 10:37:33 +02:00
|
|
|
|
|
|
|
|
|
res = g_strcmp0 (mount1->root_path, mount2->root_path);
|
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
2008-07-15 07:42:11 +02:00
|
|
|
|
res = g_strcmp0 (mount1->filesystem_type, mount2->filesystem_type);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
2018-04-26 10:36:36 +02:00
|
|
|
|
res = g_strcmp0 (mount1->options, mount2->options);
|
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
res = mount1->is_read_only - mount2->is_read_only;
|
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_get_mount_path:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry] to get the mount path for
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Gets the mount path for a Unix mount.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (type filename): the mount path for @mount_entry
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.get_mount_path] instead.
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
g_unix_mount_get_mount_path (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_get_mount_path (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_get_mount_path:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry] to get the mount path for
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Gets the mount path for a Unix mount.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (type filename): the mount path for @mount_entry
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
|
|
|
|
g_unix_mount_entry_get_mount_path (GUnixMountEntry *mount_entry)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_entry != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
return mount_entry->mount_path;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_get_device_path:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Gets the device path for a Unix mount.
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (type filename): a string containing the device path
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.get_device_path] instead.
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
g_unix_mount_get_device_path (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_get_device_path (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_get_device_path:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Gets the device path for a Unix mount.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (type filename): a string containing the device path
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
|
|
|
|
g_unix_mount_entry_get_device_path (GUnixMountEntry *mount_entry)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_entry != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
return mount_entry->device_path;
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-26 10:37:33 +02:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_get_root_path:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2018-04-26 10:37:33 +02:00
|
|
|
|
*
|
|
|
|
|
* Gets the root of the mount within the filesystem. This is useful e.g. for
|
|
|
|
|
* mounts created by bind operation, or btrfs subvolumes.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* For example, the root path is equal to `/` for a mount created by
|
|
|
|
|
* `mount /dev/sda1 /mnt/foo` and `/bar` for
|
|
|
|
|
* `mount --bind /mnt/foo/bar /mnt/bar`.
|
2018-04-26 10:37:33 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (nullable): a string containing the root, or `NULL` if not supported
|
2018-04-26 10:37:33 +02:00
|
|
|
|
* Since: 2.60
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.get_root_path] instead.
|
2018-04-26 10:37:33 +02:00
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
|
|
|
|
g_unix_mount_get_root_path (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_get_root_path (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_get_root_path:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
|
|
|
|
* Gets the root of the mount within the filesystem. This is useful e.g. for
|
|
|
|
|
* mounts created by bind operation, or btrfs subvolumes.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* For example, the root path is equal to `/` for a mount created by
|
|
|
|
|
* `mount /dev/sda1 /mnt/foo` and `/bar` for
|
|
|
|
|
* `mount --bind /mnt/foo/bar /mnt/bar`.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (nullable): a string containing the root, or `NULL` if not supported
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
|
|
|
|
g_unix_mount_entry_get_root_path (GUnixMountEntry *mount_entry)
|
2018-04-26 10:37:33 +02:00
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_entry != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
return mount_entry->root_path;
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_get_fs_type:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Gets the filesystem type for the Unix mount.
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: a string containing the file system type
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.get_fs_type] instead.
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
g_unix_mount_get_fs_type (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_get_fs_type (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_get_fs_type:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Gets the filesystem type for the Unix mount.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: a string containing the file system type
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
|
|
|
|
g_unix_mount_entry_get_fs_type (GUnixMountEntry *mount_entry)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_entry != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
return mount_entry->filesystem_type;
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-26 10:36:36 +02:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_get_options:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2018-04-26 10:36:36 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Gets a comma separated list of mount options for the Unix mount.
|
2018-04-26 10:36:36 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* For example: `rw,relatime,seclabel,data=ordered`.
|
2018-04-26 10:36:36 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* This is similar to [func@GioUnix.MountPoint.get_options], but it takes
|
|
|
|
|
* a [struct@GioUnix.MountEntry] as an argument.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (nullable): a string containing the options, or `NULL` if not
|
|
|
|
|
* available.
|
2018-04-26 10:36:36 +02:00
|
|
|
|
* Since: 2.58
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.get_options] instead.
|
2018-04-26 10:36:36 +02:00
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
|
|
|
|
g_unix_mount_get_options (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_get_options (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_get_options:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Gets a comma separated list of mount options for the Unix mount.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* For example: `rw,relatime,seclabel,data=ordered`.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* This is similar to [func@GioUnix.MountPoint.get_options], but it takes
|
|
|
|
|
* a [struct@GioUnix.MountEntry] as an argument.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (nullable): a string containing the options, or `NULL` if not
|
|
|
|
|
* available.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
|
|
|
|
g_unix_mount_entry_get_options (GUnixMountEntry *mount_entry)
|
2018-04-26 10:36:36 +02:00
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_entry != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
return mount_entry->options;
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_is_readonly:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Checks if a Unix mount is mounted read only.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if @mount_entry is read only; false otherwise
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.is_readonly] instead.
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2007-11-26 17:13:05 +01:00
|
|
|
|
gboolean
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
g_unix_mount_is_readonly (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_is_readonly (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_is_readonly:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Checks if a Unix mount is mounted read only.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if @mount_entry is read only; false otherwise
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_entry_is_readonly (GUnixMountEntry *mount_entry)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_entry != NULL, FALSE);
|
|
|
|
|
|
|
|
|
|
return mount_entry->is_read_only;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_is_system_internal:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2017-10-25 16:03:17 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Checks if a Unix mount is a system mount.
|
|
|
|
|
*
|
|
|
|
|
* This is the Boolean OR of
|
|
|
|
|
* [func@GioUnix.is_system_fs_type], [func@GioUnix.is_system_device_path] and
|
|
|
|
|
* [func@GioUnix.is_mount_path_system_internal] on @mount_entry’s properties.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2017-10-25 16:03:17 +02:00
|
|
|
|
* The definition of what a ‘system’ mount entry is may change over time as new
|
|
|
|
|
* file system types and device paths are ignored.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if the Unix mount is for a system path; false otherwise
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.is_system_internal] instead.
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2007-11-26 17:13:05 +01:00
|
|
|
|
gboolean
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
g_unix_mount_is_system_internal (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_is_system_internal (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_is_system_internal:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Checks if a Unix mount is a system mount.
|
|
|
|
|
*
|
|
|
|
|
* This is the Boolean OR of
|
|
|
|
|
* [func@GioUnix.is_system_fs_type], [func@GioUnix.is_system_device_path] and
|
|
|
|
|
* [func@GioUnix.is_mount_path_system_internal] on @mount_entry’s properties.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
|
|
|
|
* The definition of what a ‘system’ mount entry is may change over time as new
|
|
|
|
|
* file system types and device paths are ignored.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if the Unix mount is for a system path; false otherwise
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_entry_is_system_internal (GUnixMountEntry *mount_entry)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_entry != NULL, FALSE);
|
|
|
|
|
|
|
|
|
|
return mount_entry->is_system_internal;
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* GUnixMountPoint {{{1 */
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_compare:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount1: a [struct@GioUnix.MountPoint]
|
|
|
|
|
* @mount2: a [struct@GioUnix.MountPoint]
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Compares two Unix mount points.
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: `1`, `0` or `-1` if @mount1 is greater than, equal to,
|
|
|
|
|
* or less than @mount2, respectively
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2007-11-26 17:13:05 +01:00
|
|
|
|
gint
|
|
|
|
|
g_unix_mount_point_compare (GUnixMountPoint *mount1,
|
|
|
|
|
GUnixMountPoint *mount2)
|
|
|
|
|
{
|
|
|
|
|
int res;
|
|
|
|
|
|
|
|
|
|
g_return_val_if_fail (mount1 != NULL && mount2 != NULL, 0);
|
|
|
|
|
|
2008-07-15 07:42:11 +02:00
|
|
|
|
res = g_strcmp0 (mount1->mount_path, mount2->mount_path);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
2008-07-15 07:42:11 +02:00
|
|
|
|
res = g_strcmp0 (mount1->device_path, mount2->device_path);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
2008-07-15 07:42:11 +02:00
|
|
|
|
res = g_strcmp0 (mount1->filesystem_type, mount2->filesystem_type);
|
2007-11-26 17:13:05 +01:00
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
2011-09-30 05:46:28 +02:00
|
|
|
|
res = g_strcmp0 (mount1->options, mount2->options);
|
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
res = mount1->is_read_only - mount2->is_read_only;
|
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
|
|
|
|
res = mount1->is_user_mountable - mount2->is_user_mountable;
|
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
|
|
|
|
res = mount1->is_loopback - mount2->is_loopback;
|
|
|
|
|
if (res != 0)
|
|
|
|
|
return res;
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_get_mount_path:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Gets the mount path for a Unix mount point.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (type filename): a string containing the mount path
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
2007-11-26 17:13:05 +01:00
|
|
|
|
g_unix_mount_point_get_mount_path (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_point != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
return mount_point->mount_path;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_get_device_path:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Gets the device path for a Unix mount point.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (type filename): a string containing the device path
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
2007-11-26 17:13:05 +01:00
|
|
|
|
g_unix_mount_point_get_device_path (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_point != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
return mount_point->device_path;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_get_fs_type:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2007-11-27 15:00:13 +01:00
|
|
|
|
* Gets the file system type for the mount point.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: a string containing the file system type
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
2007-11-26 17:13:05 +01:00
|
|
|
|
g_unix_mount_point_get_fs_type (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_point != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
return mount_point->filesystem_type;
|
|
|
|
|
}
|
|
|
|
|
|
2011-09-30 05:46:28 +02:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_get_options:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2011-09-30 05:46:28 +02:00
|
|
|
|
*
|
|
|
|
|
* Gets the options for the mount point.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (nullable): a string containing the options
|
2011-09-30 05:46:28 +02:00
|
|
|
|
* Since: 2.32
|
|
|
|
|
*/
|
|
|
|
|
const gchar *
|
|
|
|
|
g_unix_mount_point_get_options (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_point != NULL, NULL);
|
|
|
|
|
|
|
|
|
|
return mount_point->options;
|
|
|
|
|
}
|
|
|
|
|
|
2007-11-26 17:13:05 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_is_readonly:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Checks if a Unix mount point is read only.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if a mount point is read only; false otherwise
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2007-11-26 17:13:05 +01:00
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_point_is_readonly (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_point != NULL, FALSE);
|
|
|
|
|
|
|
|
|
|
return mount_point->is_read_only;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_is_user_mountable:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Checks if a Unix mount point is mountable by the user.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if the mount point is user mountable; false otherwise
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2007-11-26 17:13:05 +01:00
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_point_is_user_mountable (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_point != NULL, FALSE);
|
|
|
|
|
|
|
|
|
|
return mount_point->is_user_mountable;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_is_loopback:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Checks if a Unix mount point is a loopback device.
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if the mount point is a loopback device; false otherwise
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2007-11-26 17:13:05 +01:00
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_point_is_loopback (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_point != NULL, FALSE);
|
|
|
|
|
|
|
|
|
|
return mount_point->is_loopback;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static GUnixMountType
|
|
|
|
|
guess_mount_type (const char *mount_path,
|
|
|
|
|
const char *device_path,
|
|
|
|
|
const char *filesystem_type)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountType type;
|
|
|
|
|
char *basename;
|
|
|
|
|
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_UNKNOWN;
|
|
|
|
|
|
|
|
|
|
if ((strcmp (filesystem_type, "udf") == 0) ||
|
|
|
|
|
(strcmp (filesystem_type, "iso9660") == 0) ||
|
|
|
|
|
(strcmp (filesystem_type, "cd9660") == 0))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_CDROM;
|
2008-03-19 15:07:00 +01:00
|
|
|
|
else if ((strcmp (filesystem_type, "nfs") == 0) ||
|
|
|
|
|
(strcmp (filesystem_type, "nfs4") == 0))
|
2007-11-26 17:13:05 +01:00
|
|
|
|
type = G_UNIX_MOUNT_TYPE_NFS;
|
|
|
|
|
else if (g_str_has_prefix (device_path, "/vol/dev/diskette/") ||
|
|
|
|
|
g_str_has_prefix (device_path, "/dev/fd") ||
|
|
|
|
|
g_str_has_prefix (device_path, "/dev/floppy"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_FLOPPY;
|
|
|
|
|
else if (g_str_has_prefix (device_path, "/dev/cdrom") ||
|
|
|
|
|
g_str_has_prefix (device_path, "/dev/acd") ||
|
|
|
|
|
g_str_has_prefix (device_path, "/dev/cd"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_CDROM;
|
|
|
|
|
else if (g_str_has_prefix (device_path, "/vol/"))
|
|
|
|
|
{
|
|
|
|
|
const char *name = mount_path + strlen ("/");
|
|
|
|
|
|
|
|
|
|
if (g_str_has_prefix (name, "cdrom"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_CDROM;
|
|
|
|
|
else if (g_str_has_prefix (name, "floppy") ||
|
|
|
|
|
g_str_has_prefix (device_path, "/vol/dev/diskette/"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_FLOPPY;
|
|
|
|
|
else if (g_str_has_prefix (name, "rmdisk"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_ZIP;
|
|
|
|
|
else if (g_str_has_prefix (name, "jaz"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_JAZ;
|
|
|
|
|
else if (g_str_has_prefix (name, "memstick"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_MEMSTICK;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
basename = g_path_get_basename (mount_path);
|
|
|
|
|
|
2008-03-14 12:15:49 +01:00
|
|
|
|
if (g_str_has_prefix (basename, "cdr") ||
|
2007-11-26 17:13:05 +01:00
|
|
|
|
g_str_has_prefix (basename, "cdwriter") ||
|
|
|
|
|
g_str_has_prefix (basename, "burn") ||
|
2008-03-14 12:15:49 +01:00
|
|
|
|
g_str_has_prefix (basename, "dvdr"))
|
2007-11-26 17:13:05 +01:00
|
|
|
|
type = G_UNIX_MOUNT_TYPE_CDROM;
|
|
|
|
|
else if (g_str_has_prefix (basename, "floppy"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_FLOPPY;
|
|
|
|
|
else if (g_str_has_prefix (basename, "zip"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_ZIP;
|
|
|
|
|
else if (g_str_has_prefix (basename, "jaz"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_JAZ;
|
|
|
|
|
else if (g_str_has_prefix (basename, "camera"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_CAMERA;
|
|
|
|
|
else if (g_str_has_prefix (basename, "memstick") ||
|
|
|
|
|
g_str_has_prefix (basename, "memory_stick") ||
|
|
|
|
|
g_str_has_prefix (basename, "ram"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_MEMSTICK;
|
|
|
|
|
else if (g_str_has_prefix (basename, "compact_flash"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_CF;
|
|
|
|
|
else if (g_str_has_prefix (basename, "smart_media"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_SM;
|
|
|
|
|
else if (g_str_has_prefix (basename, "sd_mmc"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_SDMMC;
|
|
|
|
|
else if (g_str_has_prefix (basename, "ipod"))
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_IPOD;
|
|
|
|
|
|
|
|
|
|
g_free (basename);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (type == G_UNIX_MOUNT_TYPE_UNKNOWN)
|
|
|
|
|
type = G_UNIX_MOUNT_TYPE_HD;
|
|
|
|
|
|
|
|
|
|
return type;
|
|
|
|
|
}
|
|
|
|
|
|
2014-08-18 14:08:41 +02:00
|
|
|
|
/**
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* g_unix_mount_entry_guess_type:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
|
|
|
|
*
|
|
|
|
|
* Guesses the type of a Unix mount entry.
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* If the mount type cannot be determined, returns
|
|
|
|
|
* [enum@GioUnix.MountType.UNKNOWN].
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: a [enum@GioUnix.MountType]
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2007-12-14 16:56:56 +01:00
|
|
|
|
static GUnixMountType
|
2024-10-18 11:31:12 +02:00
|
|
|
|
g_unix_mount_entry_guess_type (GUnixMountEntry *mount_entry)
|
2007-11-26 17:13:05 +01:00
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_entry != NULL, G_UNIX_MOUNT_TYPE_UNKNOWN);
|
|
|
|
|
g_return_val_if_fail (mount_entry->mount_path != NULL, G_UNIX_MOUNT_TYPE_UNKNOWN);
|
|
|
|
|
g_return_val_if_fail (mount_entry->device_path != NULL, G_UNIX_MOUNT_TYPE_UNKNOWN);
|
|
|
|
|
g_return_val_if_fail (mount_entry->filesystem_type != NULL, G_UNIX_MOUNT_TYPE_UNKNOWN);
|
|
|
|
|
|
|
|
|
|
return guess_mount_type (mount_entry->mount_path,
|
|
|
|
|
mount_entry->device_path,
|
|
|
|
|
mount_entry->filesystem_type);
|
|
|
|
|
}
|
|
|
|
|
|
2014-08-18 14:08:41 +02:00
|
|
|
|
/**
|
2007-11-26 17:13:05 +01:00
|
|
|
|
* g_unix_mount_point_guess_type:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2007-11-27 15:00:13 +01:00
|
|
|
|
*
|
2024-12-20 13:42:58 +01:00
|
|
|
|
* Guesses the type of a Unix mount point.
|
2024-12-20 16:11:41 +01:00
|
|
|
|
*
|
|
|
|
|
* If the mount type cannot be determined, returns
|
|
|
|
|
* [enum@GioUnix.MountType.UNKNOWN].
|
2007-11-26 17:13:05 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: a [enum@GioUnix.MountType]
|
2009-01-19 07:09:11 +01:00
|
|
|
|
*/
|
2007-12-14 16:56:56 +01:00
|
|
|
|
static GUnixMountType
|
2007-11-26 17:13:05 +01:00
|
|
|
|
g_unix_mount_point_guess_type (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
g_return_val_if_fail (mount_point != NULL, G_UNIX_MOUNT_TYPE_UNKNOWN);
|
|
|
|
|
g_return_val_if_fail (mount_point->mount_path != NULL, G_UNIX_MOUNT_TYPE_UNKNOWN);
|
|
|
|
|
g_return_val_if_fail (mount_point->device_path != NULL, G_UNIX_MOUNT_TYPE_UNKNOWN);
|
|
|
|
|
g_return_val_if_fail (mount_point->filesystem_type != NULL, G_UNIX_MOUNT_TYPE_UNKNOWN);
|
|
|
|
|
|
|
|
|
|
return guess_mount_type (mount_point->mount_path,
|
|
|
|
|
mount_point->device_path,
|
|
|
|
|
mount_point->filesystem_type);
|
|
|
|
|
}
|
2007-11-28 13:39:07 +01:00
|
|
|
|
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
static const char *
|
2012-08-28 21:37:43 +02:00
|
|
|
|
type_to_icon (GUnixMountType type, gboolean is_mount_point, gboolean use_symbolic)
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
{
|
|
|
|
|
const char *icon_name;
|
|
|
|
|
|
|
|
|
|
switch (type)
|
|
|
|
|
{
|
|
|
|
|
case G_UNIX_MOUNT_TYPE_HD:
|
|
|
|
|
if (is_mount_point)
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "drive-removable-media-symbolic" : "drive-removable-media";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
else
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "drive-harddisk-symbolic" : "drive-harddisk";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
break;
|
|
|
|
|
case G_UNIX_MOUNT_TYPE_FLOPPY:
|
|
|
|
|
case G_UNIX_MOUNT_TYPE_ZIP:
|
|
|
|
|
case G_UNIX_MOUNT_TYPE_JAZ:
|
|
|
|
|
if (is_mount_point)
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "drive-removable-media-symbolic" : "drive-removable-media";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
else
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "media-removable-symbolic" : "media-floppy";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
break;
|
|
|
|
|
case G_UNIX_MOUNT_TYPE_CDROM:
|
|
|
|
|
if (is_mount_point)
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "drive-optical-symbolic" : "drive-optical";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
else
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "media-optical-symbolic" : "media-optical";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
break;
|
|
|
|
|
case G_UNIX_MOUNT_TYPE_NFS:
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "folder-remote-symbolic" : "folder-remote";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
break;
|
|
|
|
|
case G_UNIX_MOUNT_TYPE_MEMSTICK:
|
|
|
|
|
if (is_mount_point)
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "drive-removable-media-symbolic" : "drive-removable-media";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
else
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "media-removable-symbolic" : "media-flash";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
break;
|
|
|
|
|
case G_UNIX_MOUNT_TYPE_CAMERA:
|
|
|
|
|
if (is_mount_point)
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "drive-removable-media-symbolic" : "drive-removable-media";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
else
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "camera-photo-symbolic" : "camera-photo";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
break;
|
|
|
|
|
case G_UNIX_MOUNT_TYPE_IPOD:
|
|
|
|
|
if (is_mount_point)
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "drive-removable-media-symbolic" : "drive-removable-media";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
else
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "multimedia-player-symbolic" : "multimedia-player";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
break;
|
|
|
|
|
case G_UNIX_MOUNT_TYPE_UNKNOWN:
|
|
|
|
|
default:
|
|
|
|
|
if (is_mount_point)
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "drive-removable-media-symbolic" : "drive-removable-media";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
else
|
2012-08-28 21:37:43 +02:00
|
|
|
|
icon_name = use_symbolic ? "drive-harddisk-symbolic" : "drive-harddisk";
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return icon_name;
|
|
|
|
|
}
|
|
|
|
|
|
2007-12-17 08:04:51 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_guess_name:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
|
|
|
|
*
|
|
|
|
|
* Guesses the name of a Unix mount entry.
|
2007-12-17 08:04:51 +01:00
|
|
|
|
*
|
|
|
|
|
* The result is a translated string.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a newly allocated translated string
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.guess_name] instead.
|
2007-12-17 08:04:51 +01:00
|
|
|
|
*/
|
2009-01-19 07:09:11 +01:00
|
|
|
|
gchar *
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
g_unix_mount_guess_name (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_guess_name (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_guess_name:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Guesses the name of a Unix mount entry.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* The result is a translated string.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a newly allocated translated string
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
gchar *
|
|
|
|
|
g_unix_mount_entry_guess_name (GUnixMountEntry *mount_entry)
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
{
|
|
|
|
|
char *name;
|
|
|
|
|
|
|
|
|
|
if (strcmp (mount_entry->mount_path, "/") == 0)
|
|
|
|
|
name = g_strdup (_("Filesystem root"));
|
|
|
|
|
else
|
|
|
|
|
name = g_filename_display_basename (mount_entry->mount_path);
|
|
|
|
|
|
|
|
|
|
return name;
|
|
|
|
|
}
|
|
|
|
|
|
2007-12-17 08:04:51 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_guess_icon:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2007-12-17 08:04:51 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Guesses the icon of a Unix mount entry.
|
2007-12-17 08:04:51 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a [iface@Gio.Icon]
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.guess_icon] instead.
|
2007-12-17 08:04:51 +01:00
|
|
|
|
*/
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
GIcon *
|
|
|
|
|
g_unix_mount_guess_icon (GUnixMountEntry *mount_entry)
|
|
|
|
|
{
|
2024-10-18 11:31:12 +02:00
|
|
|
|
return g_unix_mount_entry_guess_icon (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_guess_icon:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Guesses the icon of a Unix mount entry.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a [iface@Gio.Icon]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
GIcon *
|
|
|
|
|
g_unix_mount_entry_guess_icon (GUnixMountEntry *mount_entry)
|
|
|
|
|
{
|
|
|
|
|
return g_themed_icon_new_with_default_fallbacks (type_to_icon (g_unix_mount_entry_guess_type (mount_entry), FALSE, FALSE));
|
2012-08-28 21:37:43 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_guess_symbolic_icon:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2012-08-28 21:37:43 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Guesses the symbolic icon of a Unix mount entry.
|
2012-08-28 21:37:43 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a [iface@Gio.Icon]
|
2012-08-28 21:37:43 +02:00
|
|
|
|
* Since: 2.34
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.guess_symbolic_icon] instead.
|
2012-08-28 21:37:43 +02:00
|
|
|
|
*/
|
|
|
|
|
GIcon *
|
|
|
|
|
g_unix_mount_guess_symbolic_icon (GUnixMountEntry *mount_entry)
|
|
|
|
|
{
|
2024-10-18 11:31:12 +02:00
|
|
|
|
return g_unix_mount_entry_guess_symbolic_icon (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_guess_symbolic_icon:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Guesses the symbolic icon of a Unix mount entry.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a [iface@Gio.Icon]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
GIcon *
|
|
|
|
|
g_unix_mount_entry_guess_symbolic_icon (GUnixMountEntry *mount_entry)
|
|
|
|
|
{
|
|
|
|
|
return g_themed_icon_new_with_default_fallbacks (type_to_icon (g_unix_mount_entry_guess_type (mount_entry), FALSE, TRUE));
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
}
|
|
|
|
|
|
2007-12-17 08:04:51 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_guess_name:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
|
|
|
|
*
|
|
|
|
|
* Guesses the name of a Unix mount point.
|
2007-12-17 08:04:51 +01:00
|
|
|
|
*
|
|
|
|
|
* The result is a translated string.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a newly allocated translated string
|
2007-12-17 08:04:51 +01:00
|
|
|
|
*/
|
2009-01-19 07:09:11 +01:00
|
|
|
|
gchar *
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
g_unix_mount_point_guess_name (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
char *name;
|
|
|
|
|
|
|
|
|
|
if (strcmp (mount_point->mount_path, "/") == 0)
|
|
|
|
|
name = g_strdup (_("Filesystem root"));
|
|
|
|
|
else
|
|
|
|
|
name = g_filename_display_basename (mount_point->mount_path);
|
|
|
|
|
|
|
|
|
|
return name;
|
|
|
|
|
}
|
|
|
|
|
|
2007-12-17 08:04:51 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_guess_icon:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2007-12-17 08:04:51 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Guesses the icon of a Unix mount point.
|
2007-12-17 08:04:51 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a [iface@Gio.Icon]
|
2007-12-17 08:04:51 +01:00
|
|
|
|
*/
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
GIcon *
|
|
|
|
|
g_unix_mount_point_guess_icon (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
2012-08-28 21:37:43 +02:00
|
|
|
|
return g_themed_icon_new_with_default_fallbacks (type_to_icon (g_unix_mount_point_guess_type (mount_point), TRUE, FALSE));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_guess_symbolic_icon:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2012-08-28 21:37:43 +02:00
|
|
|
|
*
|
|
|
|
|
* Guesses the symbolic icon of a Unix mount point.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: (transfer full): a [iface@Gio.Icon]
|
2012-08-28 21:37:43 +02:00
|
|
|
|
* Since: 2.34
|
|
|
|
|
*/
|
|
|
|
|
GIcon *
|
|
|
|
|
g_unix_mount_point_guess_symbolic_icon (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
return g_themed_icon_new_with_default_fallbacks (type_to_icon (g_unix_mount_point_guess_type (mount_point), TRUE, TRUE));
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
}
|
|
|
|
|
|
2007-12-30 06:30:42 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_guess_can_eject:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2007-12-30 06:30:42 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Guesses whether a Unix mount entry can be ejected.
|
2007-12-30 06:30:42 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if @mount_entry is deemed to be ejectable; false otherwise
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.guess_can_eject] instead.
|
2007-12-30 06:30:42 +01:00
|
|
|
|
*/
|
Provide eject() on both GMount and GVolume and utility functions to guess
2007-12-14 David Zeuthen <davidz@redhat.com>
* Makefile.am:
* gio.symbols:
* gmount.c: (g_mount_get_uuid), (g_mount_can_eject),
(g_mount_eject), (g_mount_eject_finish):
* gmount.h:
* gunionvolumemonitor.c: (g_union_volume_monitor_finalize),
(get_volume_for_uuid), (get_mount_for_uuid),
(g_union_volume_monitor_class_init),
(get_default_native_type_with_exclude), (get_default_native_type),
(get_native_type), (update_native_type),
(g_union_volume_monitor_init), (_g_mount_get_for_mount_path):
* gunixmount.c: (_g_unix_mount_new), (g_unix_mount_get_uuid),
(g_unix_mount_can_eject), (eject_unmount_cb),
(eject_unmount_read_error), (eject_unmount_do),
(g_unix_mount_unmount), (g_unix_mount_eject),
(g_unix_mount_eject_finish), (g_unix_mount_mount_iface_init):
* gunixmounts.c: (g_unix_mount_guess_can_eject),
(g_unix_mount_point_guess_can_eject):
* gunixmounts.h:
* gunixvolume.c: (_g_unix_volume_new), (g_unix_volume_get_uuid),
(g_unix_volume_can_eject), (g_unix_volume_get_drive),
(eject_mount_cb), (eject_mount_read_error), (eject_mount_do),
(g_unix_volume_mount), (g_unix_volume_eject),
(g_unix_volume_eject_finish), (g_unix_volume_volume_iface_init):
* gunixvolumemonitor.c: (get_volume_for_uuid),
(get_mount_for_uuid), (g_unix_volume_monitor_class_init),
(update_mounts):
* gvolume.c: (g_volume_get_uuid), (g_volume_can_eject),
(g_volume_eject), (g_volume_eject_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_get_volume_for_uuid),
(g_volume_monitor_get_mount_for_uuid):
* gvolumemonitor.h:
Provide eject() on both GMount and GVolume and utility functions
to guess whether a GUnixMountPoint or GUnixMountEntry should be
ejected. Introduce the concept of UUID's and wire it into GVolume
and GMount and provide API on GVolumeMonitor to find such
instances. Also handle the case where an external
GNativeVolumeMonitor fails to initialize. Lock around the
_g_get_mount_for_mount_path() function such that volume monitor
implementations won't have to do locking themselves.
svn path=/trunk/; revision=6140
2007-12-17 10:31:08 +01:00
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_guess_can_eject (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_guess_can_eject (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_guess_can_eject:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Guesses whether a Unix mount entry can be ejected.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if @mount_entry is deemed to be ejectable; false otherwise
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_entry_guess_can_eject (GUnixMountEntry *mount_entry)
|
Provide eject() on both GMount and GVolume and utility functions to guess
2007-12-14 David Zeuthen <davidz@redhat.com>
* Makefile.am:
* gio.symbols:
* gmount.c: (g_mount_get_uuid), (g_mount_can_eject),
(g_mount_eject), (g_mount_eject_finish):
* gmount.h:
* gunionvolumemonitor.c: (g_union_volume_monitor_finalize),
(get_volume_for_uuid), (get_mount_for_uuid),
(g_union_volume_monitor_class_init),
(get_default_native_type_with_exclude), (get_default_native_type),
(get_native_type), (update_native_type),
(g_union_volume_monitor_init), (_g_mount_get_for_mount_path):
* gunixmount.c: (_g_unix_mount_new), (g_unix_mount_get_uuid),
(g_unix_mount_can_eject), (eject_unmount_cb),
(eject_unmount_read_error), (eject_unmount_do),
(g_unix_mount_unmount), (g_unix_mount_eject),
(g_unix_mount_eject_finish), (g_unix_mount_mount_iface_init):
* gunixmounts.c: (g_unix_mount_guess_can_eject),
(g_unix_mount_point_guess_can_eject):
* gunixmounts.h:
* gunixvolume.c: (_g_unix_volume_new), (g_unix_volume_get_uuid),
(g_unix_volume_can_eject), (g_unix_volume_get_drive),
(eject_mount_cb), (eject_mount_read_error), (eject_mount_do),
(g_unix_volume_mount), (g_unix_volume_eject),
(g_unix_volume_eject_finish), (g_unix_volume_volume_iface_init):
* gunixvolumemonitor.c: (get_volume_for_uuid),
(get_mount_for_uuid), (g_unix_volume_monitor_class_init),
(update_mounts):
* gvolume.c: (g_volume_get_uuid), (g_volume_can_eject),
(g_volume_eject), (g_volume_eject_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_get_volume_for_uuid),
(g_volume_monitor_get_mount_for_uuid):
* gvolumemonitor.h:
Provide eject() on both GMount and GVolume and utility functions
to guess whether a GUnixMountPoint or GUnixMountEntry should be
ejected. Introduce the concept of UUID's and wire it into GVolume
and GMount and provide API on GVolumeMonitor to find such
instances. Also handle the case where an external
GNativeVolumeMonitor fails to initialize. Lock around the
_g_get_mount_for_mount_path() function such that volume monitor
implementations won't have to do locking themselves.
svn path=/trunk/; revision=6140
2007-12-17 10:31:08 +01:00
|
|
|
|
{
|
|
|
|
|
GUnixMountType guessed_type;
|
|
|
|
|
|
2024-10-18 11:31:12 +02:00
|
|
|
|
guessed_type = g_unix_mount_entry_guess_type (mount_entry);
|
Provide eject() on both GMount and GVolume and utility functions to guess
2007-12-14 David Zeuthen <davidz@redhat.com>
* Makefile.am:
* gio.symbols:
* gmount.c: (g_mount_get_uuid), (g_mount_can_eject),
(g_mount_eject), (g_mount_eject_finish):
* gmount.h:
* gunionvolumemonitor.c: (g_union_volume_monitor_finalize),
(get_volume_for_uuid), (get_mount_for_uuid),
(g_union_volume_monitor_class_init),
(get_default_native_type_with_exclude), (get_default_native_type),
(get_native_type), (update_native_type),
(g_union_volume_monitor_init), (_g_mount_get_for_mount_path):
* gunixmount.c: (_g_unix_mount_new), (g_unix_mount_get_uuid),
(g_unix_mount_can_eject), (eject_unmount_cb),
(eject_unmount_read_error), (eject_unmount_do),
(g_unix_mount_unmount), (g_unix_mount_eject),
(g_unix_mount_eject_finish), (g_unix_mount_mount_iface_init):
* gunixmounts.c: (g_unix_mount_guess_can_eject),
(g_unix_mount_point_guess_can_eject):
* gunixmounts.h:
* gunixvolume.c: (_g_unix_volume_new), (g_unix_volume_get_uuid),
(g_unix_volume_can_eject), (g_unix_volume_get_drive),
(eject_mount_cb), (eject_mount_read_error), (eject_mount_do),
(g_unix_volume_mount), (g_unix_volume_eject),
(g_unix_volume_eject_finish), (g_unix_volume_volume_iface_init):
* gunixvolumemonitor.c: (get_volume_for_uuid),
(get_mount_for_uuid), (g_unix_volume_monitor_class_init),
(update_mounts):
* gvolume.c: (g_volume_get_uuid), (g_volume_can_eject),
(g_volume_eject), (g_volume_eject_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_get_volume_for_uuid),
(g_volume_monitor_get_mount_for_uuid):
* gvolumemonitor.h:
Provide eject() on both GMount and GVolume and utility functions
to guess whether a GUnixMountPoint or GUnixMountEntry should be
ejected. Introduce the concept of UUID's and wire it into GVolume
and GMount and provide API on GVolumeMonitor to find such
instances. Also handle the case where an external
GNativeVolumeMonitor fails to initialize. Lock around the
_g_get_mount_for_mount_path() function such that volume monitor
implementations won't have to do locking themselves.
svn path=/trunk/; revision=6140
2007-12-17 10:31:08 +01:00
|
|
|
|
if (guessed_type == G_UNIX_MOUNT_TYPE_IPOD ||
|
|
|
|
|
guessed_type == G_UNIX_MOUNT_TYPE_CDROM)
|
|
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
2008-01-09 16:45:56 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_guess_should_display:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2008-01-09 16:45:56 +01:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Guesses whether a Unix mount entry should be displayed in the UI.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if @mount_entry is deemed to be displayable; false otherwise
|
|
|
|
|
* Deprecated: 2.84: Use [func@GioUnix.MountEntry.guess_should_display] instead.
|
2008-01-09 16:45:56 +01:00
|
|
|
|
*/
|
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_guess_should_display (GUnixMountEntry *mount_entry)
|
2024-10-18 11:31:12 +02:00
|
|
|
|
{
|
|
|
|
|
return g_unix_mount_entry_guess_should_display (mount_entry);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_entry_guess_should_display:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_entry: a [struct@GioUnix.MountEntry]
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Guesses whether a Unix mount entry should be displayed in the UI.
|
2024-10-18 11:31:12 +02:00
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if @mount_entry is deemed to be displayable; false otherwise
|
2024-10-18 11:31:12 +02:00
|
|
|
|
* Since: 2.84
|
|
|
|
|
*/
|
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_entry_guess_should_display (GUnixMountEntry *mount_entry)
|
2008-01-09 16:45:56 +01:00
|
|
|
|
{
|
2008-02-25 12:15:06 +01:00
|
|
|
|
const char *mount_path;
|
2012-03-16 18:54:09 +01:00
|
|
|
|
const gchar *user_name;
|
|
|
|
|
gsize user_name_len;
|
2008-01-09 16:45:56 +01:00
|
|
|
|
|
|
|
|
|
/* Never display internal mountpoints */
|
2024-10-18 11:31:12 +02:00
|
|
|
|
if (g_unix_mount_entry_is_system_internal (mount_entry))
|
2008-01-09 16:45:56 +01:00
|
|
|
|
return FALSE;
|
2008-02-25 12:15:06 +01:00
|
|
|
|
|
|
|
|
|
/* Only display things in /media (which are generally user mountable)
|
2012-03-16 18:54:09 +01:00
|
|
|
|
and home dir (fuse stuff) and /run/media/$USER */
|
2008-02-25 12:15:06 +01:00
|
|
|
|
mount_path = mount_entry->mount_path;
|
|
|
|
|
if (mount_path != NULL)
|
|
|
|
|
{
|
2018-03-02 17:40:34 +01:00
|
|
|
|
const gboolean running_as_root = (getuid () == 0);
|
2011-08-12 17:10:22 +02:00
|
|
|
|
gboolean is_in_runtime_dir = FALSE;
|
2018-03-02 17:40:34 +01:00
|
|
|
|
|
2010-11-16 14:20:07 +01:00
|
|
|
|
/* Hide mounts within a dot path, suppose it was a purpose to hide this mount */
|
|
|
|
|
if (g_strstr_len (mount_path, -1, "/.") != NULL)
|
|
|
|
|
return FALSE;
|
|
|
|
|
|
2018-03-02 17:40:34 +01:00
|
|
|
|
/* Check /run/media/$USER/. If running as root, display any mounts below
|
|
|
|
|
* /run/media/. */
|
|
|
|
|
if (running_as_root)
|
|
|
|
|
{
|
|
|
|
|
if (strncmp (mount_path, "/run/media/", strlen ("/run/media/")) == 0)
|
|
|
|
|
is_in_runtime_dir = TRUE;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
user_name = g_get_user_name ();
|
|
|
|
|
user_name_len = strlen (user_name);
|
|
|
|
|
if (strncmp (mount_path, "/run/media/", strlen ("/run/media/")) == 0 &&
|
|
|
|
|
strncmp (mount_path + strlen ("/run/media/"), user_name, user_name_len) == 0 &&
|
|
|
|
|
mount_path[strlen ("/run/media/") + user_name_len] == '/')
|
|
|
|
|
is_in_runtime_dir = TRUE;
|
|
|
|
|
}
|
2011-08-12 17:10:22 +02:00
|
|
|
|
|
|
|
|
|
if (is_in_runtime_dir || g_str_has_prefix (mount_path, "/media/"))
|
2009-01-19 07:09:11 +01:00
|
|
|
|
{
|
|
|
|
|
char *path;
|
|
|
|
|
/* Avoid displaying mounts that are not accessible to the user.
|
|
|
|
|
*
|
|
|
|
|
* See http://bugzilla.gnome.org/show_bug.cgi?id=526320 for why we
|
|
|
|
|
* want to avoid g_access() for mount points which can potentially
|
|
|
|
|
* block or fail stat()'ing, such as network mounts.
|
|
|
|
|
*/
|
|
|
|
|
path = g_path_get_dirname (mount_path);
|
|
|
|
|
if (g_str_has_prefix (path, "/media/"))
|
|
|
|
|
{
|
|
|
|
|
if (g_access (path, R_OK|X_OK) != 0)
|
|
|
|
|
{
|
|
|
|
|
g_free (path);
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
2008-04-29 00:38:49 +02:00
|
|
|
|
}
|
2009-01-19 07:09:11 +01:00
|
|
|
|
g_free (path);
|
2008-12-08 05:33:41 +01:00
|
|
|
|
|
2009-01-19 07:09:11 +01:00
|
|
|
|
if (mount_entry->device_path && mount_entry->device_path[0] == '/')
|
2008-12-08 05:33:41 +01:00
|
|
|
|
{
|
|
|
|
|
struct stat st;
|
|
|
|
|
if (g_stat (mount_entry->device_path, &st) == 0 &&
|
|
|
|
|
S_ISBLK(st.st_mode) &&
|
|
|
|
|
g_access (mount_path, R_OK|X_OK) != 0)
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
2009-01-19 07:09:11 +01:00
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
2008-02-25 12:15:06 +01:00
|
|
|
|
|
2009-01-19 07:09:11 +01:00
|
|
|
|
if (g_str_has_prefix (mount_path, g_get_home_dir ()) &&
|
|
|
|
|
mount_path[strlen (g_get_home_dir())] == G_DIR_SEPARATOR)
|
2008-02-25 12:15:06 +01:00
|
|
|
|
return TRUE;
|
|
|
|
|
}
|
|
|
|
|
|
2008-01-09 16:45:56 +01:00
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
2007-12-30 06:30:42 +01:00
|
|
|
|
/**
|
|
|
|
|
* g_unix_mount_point_guess_can_eject:
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* @mount_point: a [struct@GioUnix.MountPoint]
|
2007-12-30 06:30:42 +01:00
|
|
|
|
*
|
|
|
|
|
* Guesses whether a Unix mount point can be ejected.
|
|
|
|
|
*
|
2024-12-20 16:11:41 +01:00
|
|
|
|
* Returns: true if @mount_point is deemed to be ejectable; false otherwise
|
2007-12-30 06:30:42 +01:00
|
|
|
|
*/
|
Provide eject() on both GMount and GVolume and utility functions to guess
2007-12-14 David Zeuthen <davidz@redhat.com>
* Makefile.am:
* gio.symbols:
* gmount.c: (g_mount_get_uuid), (g_mount_can_eject),
(g_mount_eject), (g_mount_eject_finish):
* gmount.h:
* gunionvolumemonitor.c: (g_union_volume_monitor_finalize),
(get_volume_for_uuid), (get_mount_for_uuid),
(g_union_volume_monitor_class_init),
(get_default_native_type_with_exclude), (get_default_native_type),
(get_native_type), (update_native_type),
(g_union_volume_monitor_init), (_g_mount_get_for_mount_path):
* gunixmount.c: (_g_unix_mount_new), (g_unix_mount_get_uuid),
(g_unix_mount_can_eject), (eject_unmount_cb),
(eject_unmount_read_error), (eject_unmount_do),
(g_unix_mount_unmount), (g_unix_mount_eject),
(g_unix_mount_eject_finish), (g_unix_mount_mount_iface_init):
* gunixmounts.c: (g_unix_mount_guess_can_eject),
(g_unix_mount_point_guess_can_eject):
* gunixmounts.h:
* gunixvolume.c: (_g_unix_volume_new), (g_unix_volume_get_uuid),
(g_unix_volume_can_eject), (g_unix_volume_get_drive),
(eject_mount_cb), (eject_mount_read_error), (eject_mount_do),
(g_unix_volume_mount), (g_unix_volume_eject),
(g_unix_volume_eject_finish), (g_unix_volume_volume_iface_init):
* gunixvolumemonitor.c: (get_volume_for_uuid),
(get_mount_for_uuid), (g_unix_volume_monitor_class_init),
(update_mounts):
* gvolume.c: (g_volume_get_uuid), (g_volume_can_eject),
(g_volume_eject), (g_volume_eject_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_get_volume_for_uuid),
(g_volume_monitor_get_mount_for_uuid):
* gvolumemonitor.h:
Provide eject() on both GMount and GVolume and utility functions
to guess whether a GUnixMountPoint or GUnixMountEntry should be
ejected. Introduce the concept of UUID's and wire it into GVolume
and GMount and provide API on GVolumeMonitor to find such
instances. Also handle the case where an external
GNativeVolumeMonitor fails to initialize. Lock around the
_g_get_mount_for_mount_path() function such that volume monitor
implementations won't have to do locking themselves.
svn path=/trunk/; revision=6140
2007-12-17 10:31:08 +01:00
|
|
|
|
gboolean
|
|
|
|
|
g_unix_mount_point_guess_can_eject (GUnixMountPoint *mount_point)
|
|
|
|
|
{
|
|
|
|
|
GUnixMountType guessed_type;
|
|
|
|
|
|
|
|
|
|
guessed_type = g_unix_mount_point_guess_type (mount_point);
|
|
|
|
|
if (guessed_type == G_UNIX_MOUNT_TYPE_IPOD ||
|
|
|
|
|
guessed_type == G_UNIX_MOUNT_TYPE_CDROM)
|
|
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
2015-01-08 05:49:47 +01:00
|
|
|
|
/* Utility functions {{{1 */
|
|
|
|
|
|
2011-09-01 11:10:38 +02:00
|
|
|
|
#ifdef HAVE_MNTENT_H
|
2023-05-10 05:11:24 +02:00
|
|
|
|
/* borrowed from gtk/gtkfilesystemunix.c in GTK on 02/23/2006 */
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
static void
|
|
|
|
|
_canonicalize_filename (gchar *filename)
|
|
|
|
|
{
|
|
|
|
|
gchar *p, *q;
|
|
|
|
|
gboolean last_was_slash = FALSE;
|
|
|
|
|
|
|
|
|
|
p = filename;
|
|
|
|
|
q = filename;
|
|
|
|
|
|
|
|
|
|
while (*p)
|
|
|
|
|
{
|
|
|
|
|
if (*p == G_DIR_SEPARATOR)
|
|
|
|
|
{
|
|
|
|
|
if (!last_was_slash)
|
|
|
|
|
*q++ = G_DIR_SEPARATOR;
|
|
|
|
|
|
|
|
|
|
last_was_slash = TRUE;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (last_was_slash && *p == '.')
|
|
|
|
|
{
|
|
|
|
|
if (*(p + 1) == G_DIR_SEPARATOR ||
|
|
|
|
|
*(p + 1) == '\0')
|
|
|
|
|
{
|
|
|
|
|
if (*(p + 1) == '\0')
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
p += 1;
|
|
|
|
|
}
|
|
|
|
|
else if (*(p + 1) == '.' &&
|
|
|
|
|
(*(p + 2) == G_DIR_SEPARATOR ||
|
|
|
|
|
*(p + 2) == '\0'))
|
|
|
|
|
{
|
|
|
|
|
if (q > filename + 1)
|
|
|
|
|
{
|
|
|
|
|
q--;
|
|
|
|
|
while (q > filename + 1 &&
|
|
|
|
|
*(q - 1) != G_DIR_SEPARATOR)
|
|
|
|
|
q--;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (*(p + 2) == '\0')
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
p += 2;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
*q++ = *p;
|
|
|
|
|
last_was_slash = FALSE;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
*q++ = *p;
|
|
|
|
|
last_was_slash = FALSE;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
p++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (q > filename + 1 && *(q - 1) == G_DIR_SEPARATOR)
|
|
|
|
|
q--;
|
|
|
|
|
|
|
|
|
|
*q = '\0';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static char *
|
|
|
|
|
_resolve_symlink (const char *file)
|
|
|
|
|
{
|
|
|
|
|
GError *error;
|
|
|
|
|
char *dir;
|
|
|
|
|
char *link;
|
|
|
|
|
char *f;
|
|
|
|
|
char *f1;
|
|
|
|
|
|
|
|
|
|
f = g_strdup (file);
|
|
|
|
|
|
2009-01-19 07:09:11 +01:00
|
|
|
|
while (g_file_test (f, G_FILE_TEST_IS_SYMLINK))
|
|
|
|
|
{
|
|
|
|
|
link = g_file_read_link (f, &error);
|
|
|
|
|
if (link == NULL)
|
|
|
|
|
{
|
|
|
|
|
g_error_free (error);
|
|
|
|
|
g_free (f);
|
|
|
|
|
f = NULL;
|
|
|
|
|
goto out;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
dir = g_path_get_dirname (f);
|
|
|
|
|
f1 = g_strdup_printf ("%s/%s", dir, link);
|
|
|
|
|
g_free (dir);
|
|
|
|
|
g_free (link);
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
g_free (f);
|
2009-01-19 07:09:11 +01:00
|
|
|
|
f = f1;
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
out:
|
|
|
|
|
if (f != NULL)
|
|
|
|
|
_canonicalize_filename (f);
|
|
|
|
|
return f;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static const char *
|
|
|
|
|
_resolve_dev_root (void)
|
|
|
|
|
{
|
|
|
|
|
static gboolean have_real_dev_root = FALSE;
|
|
|
|
|
static char real_dev_root[256];
|
|
|
|
|
struct stat statbuf;
|
|
|
|
|
|
|
|
|
|
/* see if it's cached already */
|
|
|
|
|
if (have_real_dev_root)
|
|
|
|
|
goto found;
|
|
|
|
|
|
|
|
|
|
/* otherwise we're going to find it right away.. */
|
|
|
|
|
have_real_dev_root = TRUE;
|
|
|
|
|
|
2009-01-19 07:09:11 +01:00
|
|
|
|
if (stat ("/dev/root", &statbuf) == 0)
|
|
|
|
|
{
|
|
|
|
|
if (! S_ISLNK (statbuf.st_mode))
|
|
|
|
|
{
|
|
|
|
|
dev_t root_dev = statbuf.st_dev;
|
|
|
|
|
FILE *f;
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
|
2009-01-19 07:09:11 +01:00
|
|
|
|
/* see if device with similar major:minor as /dev/root is mention
|
|
|
|
|
* in /etc/mtab (it usually is)
|
|
|
|
|
*/
|
2023-02-19 16:46:03 +01:00
|
|
|
|
f = fopen ("/etc/mtab", "re");
|
2009-01-19 07:09:11 +01:00
|
|
|
|
if (f != NULL)
|
|
|
|
|
{
|
|
|
|
|
struct mntent *entp;
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#ifdef HAVE_GETMNTENT_R
|
2009-01-19 07:09:11 +01:00
|
|
|
|
struct mntent ent;
|
2013-04-05 16:21:23 +02:00
|
|
|
|
char buf[1024];
|
2009-01-19 07:09:11 +01:00
|
|
|
|
while ((entp = getmntent_r (f, &ent, buf, sizeof (buf))) != NULL)
|
|
|
|
|
{
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#else
|
2009-01-19 07:09:11 +01:00
|
|
|
|
G_LOCK (getmntent);
|
|
|
|
|
while ((entp = getmntent (f)) != NULL)
|
|
|
|
|
{
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#endif
|
2009-01-19 07:09:11 +01:00
|
|
|
|
if (stat (entp->mnt_fsname, &statbuf) == 0 &&
|
|
|
|
|
statbuf.st_dev == root_dev)
|
|
|
|
|
{
|
|
|
|
|
strncpy (real_dev_root, entp->mnt_fsname, sizeof (real_dev_root) - 1);
|
|
|
|
|
real_dev_root[sizeof (real_dev_root) - 1] = '\0';
|
|
|
|
|
fclose (f);
|
|
|
|
|
goto found;
|
|
|
|
|
}
|
|
|
|
|
}
|
2008-02-10 06:20:00 +01:00
|
|
|
|
|
2009-01-19 07:09:11 +01:00
|
|
|
|
endmntent (f);
|
2008-02-10 06:20:00 +01:00
|
|
|
|
|
|
|
|
|
#ifndef HAVE_GETMNTENT_R
|
2009-01-19 07:09:11 +01:00
|
|
|
|
G_UNLOCK (getmntent);
|
2008-02-10 06:20:00 +01:00
|
|
|
|
#endif
|
2009-01-19 07:09:11 +01:00
|
|
|
|
}
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
|
2009-01-19 07:09:11 +01:00
|
|
|
|
/* no, that didn't work.. next we could scan /dev ... but I digress.. */
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
|
2009-01-19 07:09:11 +01:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
char *resolved;
|
|
|
|
|
resolved = _resolve_symlink ("/dev/root");
|
|
|
|
|
if (resolved != NULL)
|
|
|
|
|
{
|
|
|
|
|
strncpy (real_dev_root, resolved, sizeof (real_dev_root) - 1);
|
|
|
|
|
real_dev_root[sizeof (real_dev_root) - 1] = '\0';
|
|
|
|
|
g_free (resolved);
|
|
|
|
|
goto found;
|
|
|
|
|
}
|
|
|
|
|
}
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* bah sucks.. */
|
|
|
|
|
strcpy (real_dev_root, "/dev/root");
|
|
|
|
|
|
2009-01-19 07:09:11 +01:00
|
|
|
|
found:
|
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com>
Rework how volumes, drives and volume monitoring is
done. Previosly the model was
GDrive <1-1> GVolume
where a GDrive instance represented a mount point and a GVolume
instance represented a mounted file system. This patch changes it
the model to
GDrive <1-N> GVolume <1-1> GMount
where GMount now serves the purpose of the old GVolume and the new
GVolume serves the purpose of the old GDrive. In addition the new
GDrive interface is used to represent a collection of GVolume
instances (typically partitions) and also contains utility to query
the state of the physical drive the GDrive object represents (such
as checking for media, polling the drive, ejecting the media etc.).
Also implement mounting and unmounting in the Unix volume monitor
backend. A subquent patch will introduce GDrive support for ejection
of media.
* Makefile.am:
* gdrive.c: (g_drive_is_media_check_automatic),
(g_drive_is_media_removable), (g_drive_has_media),
(g_drive_can_poll_for_media), (g_drive_eject),
(g_drive_eject_finish), (g_drive_poll_for_media),
(g_drive_poll_for_media_finish):
* gdrive.h:
* gfile.c: (g_file_find_enclosing_mount):
* gfile.h:
* gio.symbols:
* glocaldirectorymonitor.c:
(g_local_directory_monitor_constructor), (mounts_changed):
* glocalfile.c: (get_mount_info),
(g_local_file_find_enclosing_mount),
(g_local_file_file_iface_init):
* gnativevolumemonitor.h:
* gunionvolumemonitor.c: (get_mounts), (get_volumes),
(get_connected_drives), (g_union_volume_monitor_class_init),
(child_volume_added), (child_volume_removed),
(child_volume_changed), (child_mount_added), (child_mount_removed),
(child_mount_pre_unmount), (child_mount_changed),
(child_drive_changed), (g_union_volume_monitor_add_monitor),
(g_union_volume_monitor_remove_monitor),
(_g_mount_get_for_mount_path):
* gunixmounts.c: (g_unix_is_mount_path_system_internal),
(guess_system_internal), (_g_get_unix_mounts),
(_g_get_unix_mount_points), (g_get_unix_mount_at),
(g_unix_mount_free), (g_unix_mount_compare),
(g_unix_mount_get_mount_path), (g_unix_mount_get_device_path),
(g_unix_mount_get_fs_type), (g_unix_mount_is_readonly),
(g_unix_mount_is_system_internal), (g_unix_mount_guess_type),
(type_to_icon), (g_unix_mount_guess_name),
(g_unix_mount_guess_icon), (g_unix_mount_point_guess_name),
(g_unix_mount_point_guess_icon), (_canonicalize_filename),
(_resolve_symlink), (_resolve_dev_root):
* gunixmounts.h:
* gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new),
(_g_unix_volume_disconnected), (_g_unix_volume_set_mount),
(_g_unix_volume_unset_mount), (g_unix_volume_get_icon),
(g_unix_volume_get_name), (g_unix_volume_can_mount),
(g_unix_volume_get_drive), (g_unix_volume_get_mount),
(_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error),
(g_unix_volume_mount), (g_unix_volume_mount_finish),
(g_unix_volume_volume_iface_init):
* gunixvolume.h:
* gunixvolumemonitor.c: (g_unix_volume_monitor_finalize),
(get_mounts), (get_volumes), (get_connected_drives),
(get_mount_for_mount_path), (g_unix_volume_monitor_class_init),
(mountpoints_changed), (mounts_changed),
(g_unix_volume_monitor_init),
(_g_unix_volume_monitor_lookup_volume_for_mount_path),
(find_mount_by_mountpath), (update_volumes), (update_mounts):
* gunixvolumemonitor.h:
* gvolume.c: (g_volume_get_mount), (g_volume_can_mount),
(g_volume_mount), (g_volume_mount_finish):
* gvolume.h:
* gvolumemonitor.c: (g_volume_monitor_class_init),
(g_volume_monitor_get_connected_drives),
(g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts):
* gvolumemonitor.h:
svn path=/trunk/; revision=6095
2007-12-11 22:23:55 +01:00
|
|
|
|
return real_dev_root;
|
|
|
|
|
}
|
2007-12-17 11:53:53 +01:00
|
|
|
|
#endif
|
2015-01-08 05:49:47 +01:00
|
|
|
|
|
|
|
|
|
/* Epilogue {{{1 */
|
|
|
|
|
/* vim:set foldmethod=marker: */
|