/* vi: set sw=4 ts=4 wrap ai: */ /* * caja-widget-view-provider.c: This file is part of caja. * * Copyright (C) 2019 Wu Xiaotian * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. * */ #include #include "caja-widget-view-provider.h" #include /** * SECTION:caja-widget-view-provider * @title: CajaWidgetViewProvider * @short_description: Interface to provide widgets view. * @include: libcaja-extension/caja-widget-view-provider.h * * #CajaWidgetViewProvider allows extension to provide widgets view * in the file manager. */ static void caja_widget_view_provider_base_init (gpointer g_class) { } GType caja_widget_view_provider_get_type (void) { static GType type = 0; if (!type) { const GTypeInfo info = { sizeof (CajaWidgetViewProviderIface), caja_widget_view_provider_base_init, NULL, NULL, NULL, NULL, 0, 0, NULL }; type = g_type_register_static (G_TYPE_INTERFACE, "CajaWidgetViewProvider", &info, 0); g_type_interface_add_prerequisite (type, G_TYPE_OBJECT); } return type; } /** * caja_widget_view_provider_get_widget: * @provider: a #CajaWidgetViewProvider * * Return a #GtkWidget to show the current location content. * * Returns: The #GtkWidget used to show the contents. **/ GtkWidget * caja_widget_view_provider_get_widget (CajaWidgetViewProvider *provider) { g_return_val_if_fail (CAJA_IS_WIDGET_VIEW_PROVIDER (provider), NULL); g_return_val_if_fail (CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->get_widget != NULL, NULL); return CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->get_widget (provider); } /** * caja_widget_view_provider_add_file: * @provider: a #CajaWidgetViewProvider * @file: add a #CajaFile into the widget view. * @directory: the directory of the file. * * Add a file of this location into the widget view. **/ void caja_widget_view_provider_add_file (CajaWidgetViewProvider *provider, CajaFile *file, CajaFile *directory) { g_return_if_fail (CAJA_IS_WIDGET_VIEW_PROVIDER (provider)); g_return_if_fail (CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->add_file != NULL); CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->add_file (provider, file, directory); } /** * caja_widget_view_provider_set_location: * @provider: a #CajaWidgetViewProvider * @uri: the URI of the location * * Set the location of this #CajaWidgetViewProvider. **/ void caja_widget_view_provider_set_location (CajaWidgetViewProvider *provider, const char *location) { g_return_if_fail (CAJA_IS_WIDGET_VIEW_PROVIDER (provider)); g_return_if_fail (CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->set_location != NULL); CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->set_location (provider, location); } /** * caja_widget_view_provider_set_window: * @provider: a #CajaWidgetViewProvider * @window: parent #GtkWindow * * Set parent #GtkWindow of this #CajaWidgetViewProvider. **/ void caja_widget_view_provider_set_window (CajaWidgetViewProvider *provider, GtkWindow *window) { g_return_if_fail (CAJA_IS_WIDGET_VIEW_PROVIDER (provider)); g_return_if_fail (CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->set_window != NULL); CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->set_window (provider, window); } /** * caja_widget_view_provider_get_item_count: * @provider: a #CajaWidgetViewProvider * * Return value: The item count of this #CajaWidgetViewProvider **/ guint caja_widget_view_provider_get_item_count (CajaWidgetViewProvider *provider) { g_return_val_if_fail (CAJA_IS_WIDGET_VIEW_PROVIDER (provider), 0); g_return_val_if_fail (CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->get_item_count != NULL, 0); return CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->get_item_count (provider); } /** * caja_widget_view_provider_get_first_visible_file: * @provider: a #CajaWidgetViewProvider * * Return the first visible file. When use start visit the location, the caja's status is waiting, until * get the first visible file. * * Return value: the first visible file. **/ gchar* caja_widget_view_provider_get_first_visible_file (CajaWidgetViewProvider *provider) { g_return_val_if_fail (CAJA_IS_WIDGET_VIEW_PROVIDER (provider), NULL); g_return_val_if_fail (CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->get_first_visible_file != NULL, NULL); return CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->get_first_visible_file (provider); } /** * caja_widget_view_provider_clear: * @provider: a #CajaWidgetViewProvider * * Clear the content of this widget view. **/ void caja_widget_view_provider_clear (CajaWidgetViewProvider *provider) { g_return_if_fail (CAJA_IS_WIDGET_VIEW_PROVIDER (provider)); g_return_if_fail (CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->clear != NULL); CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->clear (provider); } /** * caja_widget_view_provider_supports_uri: * @provider: a #CajaWidgetViewProvider * @uri: the location to visit. * @file_type: The #GFileType for the uri * @mime_type: The mimetype for the uri * * Whether this widget view works for the uri. * * Return value: True to use custom widget view, False to ignore, and caja use normal view. **/ gboolean caja_widget_view_provider_supports_uri (CajaWidgetViewProvider *provider, const char *uri, GFileType file_type, const char *mime_type) { g_return_val_if_fail (CAJA_IS_WIDGET_VIEW_PROVIDER (provider), FALSE); g_return_val_if_fail (CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->supports_uri!= NULL, FALSE); return CAJA_WIDGET_VIEW_PROVIDER_GET_IFACE (provider)->supports_uri (provider, uri, file_type, mime_type); }