/* nautilus-file-utilities.h - interface for file manipulation routines. Copyright (C) 1999, 2000, 2001 Eazel, Inc. The Gnome 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. The Gnome 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 the Gnome Library; see the file COPYING.LIB. If not, see . Authors: John Sullivan */ #pragma once #include #include #include #include "nautilus-query.h" #define NAUTILUS_DESKTOP_ID APPLICATION_ID ".desktop" /* These functions all return something something that needs to be * freed with g_free, is not NULL, and is guaranteed to exist. */ char * nautilus_get_user_directory (void); char * nautilus_get_home_directory_uri (void); gboolean nautilus_is_root_directory (GFile *dir); gboolean nautilus_is_home_directory (GFile *dir); gboolean nautilus_is_home_directory_file (GFile *dir, const char *filename); gboolean nautilus_is_search_directory (GFile *dir); gboolean nautilus_is_recent_directory (GFile *dir); gboolean nautilus_is_starred_directory (GFile *dir); gboolean nautilus_is_trash_directory (GFile *dir); gboolean nautilus_is_other_locations_directory (GFile *dir); GMount * nautilus_get_mounted_mount_for_root (GFile *location); gboolean nautilus_should_use_templates_directory (void); char * nautilus_get_templates_directory (void); char * nautilus_get_templates_directory_uri (void); char * nautilus_compute_title_for_location (GFile *file); gboolean nautilus_is_file_roller_installed (void); GIcon * nautilus_special_directory_get_icon (GUserDirectory directory); GIcon * nautilus_special_directory_get_symbolic_icon (GUserDirectory directory); gboolean nautilus_uri_parse (const char *uri, char **host, guint16 *port, char **userinfo); /* Return an allocated file location that is guranteed to be unique, but * tries to make the location name readable to users. * This isn't race-free, so don't use for security-related things */ GFile * nautilus_generate_unique_file_in_directory (GFile *directory, const char *basename); GFile * nautilus_find_existing_uri_in_hierarchy (GFile *location); char * nautilus_get_scripts_directory_path (void); GHashTable * nautilus_trashed_files_get_original_directories (GList *files, GList **unhandled_files); void nautilus_restore_files_from_trash (GList *files, GtkWindow *parent_window); typedef void (*NautilusMountGetContent) (const char **content, gpointer user_data); char ** nautilus_get_cached_x_content_types_for_mount (GMount *mount); void nautilus_get_x_content_types_for_mount_async (GMount *mount, NautilusMountGetContent callback, GCancellable *cancellable, gpointer user_data); char * get_message_for_content_type (const char *content_type); char * get_message_for_two_content_types (const char * const *content_types); gboolean should_handle_content_type (const char *content_type); gboolean should_handle_content_types (const char * const *content_type); gboolean nautilus_file_selection_equal (GList *selection_a, GList *selection_b); /** * nautilus_get_common_filename_prefix: * @file_list: set of files (NautilusFile *) * @min_required_len: the minimum number of characters required in the prefix * * Returns: the common filename prefix for a set of files, or NULL if * there isn't a common prefix of length min_required_len */ char * nautilus_get_common_filename_prefix (GList *file_list, int min_required_len); /** * nautilus_get_common_filename_prefix_from_filenames: * @filename_list: set of file names (char *) * @min_required_len: the minimum number of characters required in the prefix * * Returns: the common filename prefix for a set of filenames, or NULL if * there isn't a common prefix of length min_required_len */ char * nautilus_get_common_filename_prefix_from_filenames (GList *filename_list, int min_required_len); /** * nautilus_get_max_child_name_for_location: * @location: a #GFile representing a directory * * Gets the maximum file name length for files inside @location. * * This call does blocking I/O. * * Returns: The maximum file name length in bytes (not including the * terminating null of a filename string), -1 if the maximum length * could not be determined or 0 if @location path is too long. */ glong nautilus_get_max_child_name_length_for_location (GFile *location); void nautilus_ensure_extension_points (void); void nautilus_ensure_extension_builtins (void); gboolean nautilus_file_can_rename_files (GList *files); GList * nautilus_file_list_from_uri_list (GList *uris); gchar * nautilus_uri_to_native_uri (const gchar *uri); NautilusQueryRecursive location_settings_search_get_recursive (void); NautilusQueryRecursive location_settings_search_get_recursive_for_location (GFile *location); gboolean check_schema_available (const gchar *schema_id);