nautilus/libnautilus-extension/nautilus-file-info.c
2018-02-13 20:11:55 +01:00

448 lines
11 KiB
C

/*
* nautilus-file-info.c - Information about a file
*
* Copyright (C) 2003 Novell, Inc.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, see <http://www.gnu.org/licenses/>.
*
*/
#include "nautilus-file-info.h"
#include "nautilus-extension-private.h"
G_DEFINE_INTERFACE (NautilusFileInfo, nautilus_file_info, G_TYPE_OBJECT)
NautilusFileInfo * (*nautilus_file_info_getter)(GFile * location, gboolean create);
/**
* SECTION:nautilus-file-info
* @title: NautilusFileInfo
* @short_description: File interface for nautilus extensions
*
* #NautilusFileInfo provides methods to get and modify information
* about file objects in the file manager.
*/
/**
* nautilus_file_info_list_copy:
* @files: (element-type NautilusFileInfo): the files to copy
*
* Returns: (element-type NautilusFileInfo) (transfer full): a copy of @files.
* Use #nautilus_file_info_list_free to free the list and unref its contents.
*/
GList *
nautilus_file_info_list_copy (GList *files)
{
GList *ret;
GList *l;
ret = g_list_copy (files);
for (l = ret; l != NULL; l = l->next)
{
g_object_ref (G_OBJECT (l->data));
}
return ret;
}
/**
* nautilus_file_info_list_free:
* @files: (element-type NautilusFileInfo): a list created with
* #nautilus_file_info_list_copy
*
*/
void
nautilus_file_info_list_free (GList *files)
{
GList *l;
for (l = files; l != NULL; l = l->next)
{
g_object_unref (G_OBJECT (l->data));
}
g_list_free (files);
}
static void
nautilus_file_info_default_init (NautilusFileInfoInterface *klass)
{
}
gboolean
nautilus_file_info_is_gone (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), FALSE);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->is_gone != NULL, FALSE);
return iface->is_gone (self);
}
GFileType
nautilus_file_info_get_file_type (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), G_FILE_TYPE_UNKNOWN);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_file_type != NULL, G_FILE_TYPE_UNKNOWN);
return iface->get_file_type (self);
}
char *
nautilus_file_info_get_name (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_name != NULL, NULL);
return iface->get_name (self);
}
/**
* nautilus_file_info_get_location:
* @file_info: a #NautilusFileInfo
*
* Returns: (transfer full): a #GFile for the location of @file_info
*/
GFile *
nautilus_file_info_get_location (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_location != NULL, NULL);
return iface->get_location (self);
}
char *
nautilus_file_info_get_uri (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_uri != NULL, NULL);
return iface->get_uri (self);
}
char *
nautilus_file_info_get_activation_uri (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_activation_uri != NULL, NULL);
return iface->get_activation_uri (self);
}
/**
* nautilus_file_info_get_parent_location:
* @file_info: a #NautilusFileInfo
*
* Returns: (allow-none) (transfer full): a #GFile for the parent location of @file_info,
* or %NULL if @file_info has no parent
*/
GFile *
nautilus_file_info_get_parent_location (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_parent_location != NULL, NULL);
return iface->get_parent_location (self);
}
char *
nautilus_file_info_get_parent_uri (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_parent_uri != NULL, NULL);
return iface->get_parent_uri (self);
}
/**
* nautilus_file_info_get_parent_info:
* @file_info: a #NautilusFileInfo
*
* Returns: (allow-none) (transfer full): a #NautilusFileInfo for the parent of @file_info,
* or %NULL if @file_info has no parent
*/
NautilusFileInfo *
nautilus_file_info_get_parent_info (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_parent_info != NULL, NULL);
return iface->get_parent_info (self);
}
/**
* nautilus_file_info_get_mount:
* @file_info: a #NautilusFileInfo
*
* Returns: (allow-none) (transfer full): a #GMount for the mount of @file_info,
* or %NULL if @file_info has no mount
*/
GMount *
nautilus_file_info_get_mount (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_mount != NULL, NULL);
return iface->get_mount (self);
}
char *
nautilus_file_info_get_uri_scheme (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_uri_scheme != NULL, NULL);
return iface->get_uri_scheme (self);
}
char *
nautilus_file_info_get_mime_type (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_mime_type != NULL, NULL);
return iface->get_mime_type (self);
}
gboolean
nautilus_file_info_is_mime_type (NautilusFileInfo *self,
const char *mime_type)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), FALSE);
g_return_val_if_fail (mime_type != NULL, FALSE);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->is_mime_type != NULL, FALSE);
return iface->is_mime_type (self, mime_type);
}
gboolean
nautilus_file_info_is_directory (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), FALSE);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->is_directory != NULL, FALSE);
return iface->is_directory (self);
}
gboolean
nautilus_file_info_can_write (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), FALSE);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->can_write != NULL, FALSE);
return iface->can_write (self);
}
void
nautilus_file_info_add_emblem (NautilusFileInfo *self,
const char *emblem_name)
{
NautilusFileInfoInterface *iface;
g_return_if_fail (NAUTILUS_IS_FILE_INFO (self));
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_if_fail (iface->add_emblem != NULL);
iface->add_emblem (self, emblem_name);
}
char *
nautilus_file_info_get_string_attribute (NautilusFileInfo *self,
const char *attribute_name)
{
NautilusFileInfoInterface *iface;
g_return_val_if_fail (NAUTILUS_IS_FILE_INFO (self), NULL);
g_return_val_if_fail (attribute_name != NULL, NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_val_if_fail (iface->get_string_attribute != NULL, NULL);
return iface->get_string_attribute (self, attribute_name);
}
void
nautilus_file_info_add_string_attribute (NautilusFileInfo *self,
const char *attribute_name,
const char *value)
{
NautilusFileInfoInterface *iface;
g_return_if_fail (NAUTILUS_IS_FILE_INFO (self));
g_return_if_fail (attribute_name != NULL);
g_return_if_fail (value != NULL);
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_if_fail (iface->add_string_attribute != NULL);
iface->add_string_attribute (self, attribute_name, value);
}
void
nautilus_file_info_invalidate_extension_info (NautilusFileInfo *self)
{
NautilusFileInfoInterface *iface;
g_return_if_fail (NAUTILUS_IS_FILE_INFO (self));
iface = NAUTILUS_FILE_INFO_GET_IFACE (self);
g_return_if_fail (iface->invalidate_extension_info != NULL);
iface->invalidate_extension_info (self);
}
/**
* nautilus_file_info_lookup:
* @location: the location to lookup the file info for
*
* Returns: (transfer full): a #NautilusFileInfo
*/
NautilusFileInfo *
nautilus_file_info_lookup (GFile *location)
{
g_return_val_if_fail (G_IS_FILE (location), NULL);
return nautilus_file_info_getter (location, FALSE);
}
/**
* nautilus_file_info_create:
* @location: the location to create the file info for
*
* Returns: (transfer full): a #NautilusFileInfo
*/
NautilusFileInfo *
nautilus_file_info_create (GFile *location)
{
g_return_val_if_fail (G_IS_FILE (location), NULL);
return nautilus_file_info_getter (location, TRUE);
}
/**
* nautilus_file_info_lookup_for_uri:
* @uri: the URI to lookup the file info for
*
* Returns: (transfer full): a #NautilusFileInfo
*/
NautilusFileInfo *
nautilus_file_info_lookup_for_uri (const char *uri)
{
g_autoptr (GFile) location = NULL;
g_return_val_if_fail (uri != NULL, NULL);
location = g_file_new_for_uri (uri);
return nautilus_file_info_lookup (location);
}
/**
* nautilus_file_info_create_for_uri:
* @uri: the URI to lookup the file info for
*
* Returns: (transfer full): a #NautilusFileInfo
*/
NautilusFileInfo *
nautilus_file_info_create_for_uri (const char *uri)
{
g_autoptr (GFile) location = NULL;
g_return_val_if_fail (uri != NULL, NULL);
location = g_file_new_for_uri (uri);
return nautilus_file_info_create (location);
}