X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=gio%2Fgvolume.h;h=c9421b1c9ab761223d8137cfc66edd03723cbfd0;hb=51fac05d73f8363de821eb0d6940dedca13a8c0f;hp=5496d26c4abe33c19057b2f7c9bf7b7b89ceb382;hpb=1b033919845cef366842373da9f1cfb56f522d01;p=platform%2Fupstream%2Fglib.git diff --git a/gio/gvolume.h b/gio/gvolume.h index 5496d26..c9421b1 100644 --- a/gio/gvolume.h +++ b/gio/gvolume.h @@ -13,21 +13,19 @@ * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General - * Public License along with this library; if not, write to the - * Free Software Foundation, Inc., 59 Temple Place, Suite 330, - * Boston, MA 02111-1307, USA. + * Public License along with this library; if not, see . * * Author: Alexander Larsson * David Zeuthen */ +#ifndef __G_VOLUME_H__ +#define __G_VOLUME_H__ + #if !defined (__GIO_GIO_H_INSIDE__) && !defined (GIO_COMPILATION) #error "Only can be included directly." #endif -#ifndef __G_VOLUME_H__ -#define __G_VOLUME_H__ - #include G_BEGIN_DECLS @@ -67,6 +65,21 @@ G_BEGIN_DECLS */ #define G_VOLUME_IDENTIFIER_KIND_NFS_MOUNT "nfs-mount" +/** + * G_VOLUME_IDENTIFIER_KIND_CLASS: + * + * The string used to obtain the volume class with g_volume_get_identifier(). + * + * Known volume classes include `device` and `network`. Other classes may + * be added in the future. + * + * This is intended to be used by applications to classify #GVolume + * instances into different sections - for example a file manager or + * file chooser can use this information to show `network` volumes under + * a "Network" heading and `device` volumes under a "Devices" heading. + */ +#define G_VOLUME_IDENTIFIER_KIND_CLASS "class" + #define G_TYPE_VOLUME (g_volume_get_type ()) #define G_VOLUME(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), G_TYPE_VOLUME, GVolume)) @@ -92,15 +105,17 @@ G_BEGIN_DECLS * @mount_finish: Finishes a mount operation. * @eject: Ejects a given #GVolume. * @eject_finish: Finishes an eject operation. - * @get_identifier: Returns the identifier of the given kind, or %NULL if + * @get_identifier: Returns the [identifier][volume-identifier] of the given kind, or %NULL if * the #GVolume doesn't have one. * @enumerate_identifiers: Returns an array strings listing the kinds - * of identifiers which the #GVolume has. + * of [identifiers][volume-identifier] which the #GVolume has. * @should_automount: Returns %TRUE if the #GVolume should be automatically mounted. * @get_activation_root: Returns the activation root for the #GVolume if it is known in advance or %NULL if * it is not known. * @eject_with_operation: Starts ejecting a #GVolume using a #GMountOperation. Since 2.22. * @eject_with_operation_finish: Finishes an eject operation using a #GMountOperation. Since 2.22. + * @get_sort_key: Gets a key used for sorting #GVolume instance or %NULL if no such key exists. Since 2.32. + * @get_symbolic_icon: Gets a symbolic #GIcon for the #GVolume. Since 2.34. * * Interface for implementing operations for mountable volumes. **/ @@ -159,53 +174,78 @@ struct _GVolumeIface gboolean (* eject_with_operation_finish) (GVolume *volume, GAsyncResult *result, GError **error); + + const gchar * (* get_sort_key) (GVolume *volume); + GIcon * (* get_symbolic_icon) (GVolume *volume); }; +GLIB_AVAILABLE_IN_ALL GType g_volume_get_type (void) G_GNUC_CONST; +GLIB_AVAILABLE_IN_ALL char * g_volume_get_name (GVolume *volume); +GLIB_AVAILABLE_IN_ALL GIcon * g_volume_get_icon (GVolume *volume); +GLIB_AVAILABLE_IN_ALL +GIcon * g_volume_get_symbolic_icon (GVolume *volume); +GLIB_AVAILABLE_IN_ALL char * g_volume_get_uuid (GVolume *volume); +GLIB_AVAILABLE_IN_ALL GDrive * g_volume_get_drive (GVolume *volume); +GLIB_AVAILABLE_IN_ALL GMount * g_volume_get_mount (GVolume *volume); +GLIB_AVAILABLE_IN_ALL gboolean g_volume_can_mount (GVolume *volume); +GLIB_AVAILABLE_IN_ALL gboolean g_volume_can_eject (GVolume *volume); +GLIB_AVAILABLE_IN_ALL gboolean g_volume_should_automount (GVolume *volume); +GLIB_AVAILABLE_IN_ALL void g_volume_mount (GVolume *volume, GMountMountFlags flags, GMountOperation *mount_operation, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer user_data); +GLIB_AVAILABLE_IN_ALL gboolean g_volume_mount_finish (GVolume *volume, GAsyncResult *result, GError **error); -#ifndef G_DISABLE_DEPRECATED +GLIB_DEPRECATED_FOR(g_volume_eject_with_operation) void g_volume_eject (GVolume *volume, - GMountUnmountFlags flags, - GCancellable *cancellable, - GAsyncReadyCallback callback, - gpointer user_data); + GMountUnmountFlags flags, + GCancellable *cancellable, + GAsyncReadyCallback callback, + gpointer user_data); + +GLIB_DEPRECATED_FOR(g_volume_eject_with_operation_finish) gboolean g_volume_eject_finish (GVolume *volume, - GAsyncResult *result, - GError **error); -#endif + GAsyncResult *result, + GError **error); +GLIB_AVAILABLE_IN_ALL char * g_volume_get_identifier (GVolume *volume, const char *kind); +GLIB_AVAILABLE_IN_ALL char ** g_volume_enumerate_identifiers (GVolume *volume); +GLIB_AVAILABLE_IN_ALL GFile * g_volume_get_activation_root (GVolume *volume); +GLIB_AVAILABLE_IN_ALL void g_volume_eject_with_operation (GVolume *volume, GMountUnmountFlags flags, GMountOperation *mount_operation, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer user_data); +GLIB_AVAILABLE_IN_ALL gboolean g_volume_eject_with_operation_finish (GVolume *volume, GAsyncResult *result, GError **error); +GLIB_AVAILABLE_IN_2_32 +const gchar *g_volume_get_sort_key (GVolume *volume); + G_END_DECLS #endif /* __G_VOLUME_H__ */