X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=gio%2Fgvolume.h;h=c9421b1c9ab761223d8137cfc66edd03723cbfd0;hb=e55a953642a9e402f4363f9fa347b6061dd78990;hp=bf28a56929cf17dd6c2a2043bbcddc79707d1d5b;hpb=915e2238c478737def2f8919204ee10d06ecb98a;p=platform%2Fupstream%2Fglib.git diff --git a/gio/gvolume.h b/gio/gvolume.h index bf28a56..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,16 +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. **/ @@ -162,28 +176,41 @@ struct _GVolumeIface 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, @@ -195,23 +222,28 @@ GLIB_DEPRECATED_FOR(g_volume_eject_with_operation_finish) gboolean g_volume_eject_finish (GVolume *volume, GAsyncResult *result, GError **error); -#endif +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