2 * Copyright 2015 Red Hat, Inc.
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
17 * Author: Matthias Clasen <mclasen@redhat.com>
28 static gboolean force = FALSE;
29 static gboolean empty = FALSE;
30 static const GOptionEntry entries[] = {
31 { "force", 'f', 0, G_OPTION_ARG_NONE, &force, N_("Ignore nonexistent files, never prompt"), NULL },
32 { "empty", 0, 0, G_OPTION_ARG_NONE, &empty, N_("Empty the trash"), NULL },
37 delete_trash_file (GFile *file, gboolean del_file, gboolean del_children)
41 GFileEnumerator *enumerator;
43 g_return_if_fail (g_file_has_uri_scheme (file, "trash"));
47 enumerator = g_file_enumerate_children (file,
48 G_FILE_ATTRIBUTE_STANDARD_NAME ","
49 G_FILE_ATTRIBUTE_STANDARD_TYPE,
50 G_FILE_QUERY_INFO_NOFOLLOW_SYMLINKS,
55 while ((info = g_file_enumerator_next_file (enumerator, NULL, NULL)) != NULL)
57 child = g_file_get_child (file, g_file_info_get_name (info));
59 /* The g_file_delete operation works differently for locations
60 * provided by the trash backend as it prevents modifications of
61 * trashed items. For that reason, it is enough to call
62 * g_file_delete on top-level items only.
64 delete_trash_file (child, TRUE, FALSE);
66 g_object_unref (child);
67 g_object_unref (info);
69 g_file_enumerator_close (enumerator, NULL, NULL);
70 g_object_unref (enumerator);
75 g_file_delete (file, NULL, NULL);
79 handle_trash (int argc, char *argv[], gboolean do_help)
81 GOptionContext *context;
87 g_set_prgname ("gio trash");
89 /* Translators: commandline placeholder */
90 param = g_strdup_printf ("[%s…]", _("LOCATION"));
91 context = g_option_context_new (param);
93 g_option_context_set_help_enabled (context, FALSE);
94 g_option_context_set_summary (context,
95 _("Move files or directories to the trash."));
96 g_option_context_add_main_entries (context, entries, GETTEXT_PACKAGE);
100 show_help (context, NULL);
101 g_option_context_free (context);
105 if (!g_option_context_parse (context, &argc, &argv, &error))
107 show_help (context, error->message);
108 g_error_free (error);
109 g_option_context_free (context);
117 for (i = 1; i < argc; i++)
119 file = g_file_new_for_commandline_arg (argv[i]);
121 if (!g_file_trash (file, NULL, &error))
124 !g_error_matches (error, G_IO_ERROR, G_IO_ERROR_NOT_FOUND))
126 print_file_error (file, error->message);
129 g_error_free (error);
131 g_object_unref (file);
138 file = g_file_new_for_uri ("trash:");
139 delete_trash_file (file, FALSE, TRUE);
140 g_object_unref (file);
143 if (argc == 1 && !empty)
145 show_help (context, _("No locations given"));
146 g_option_context_free (context);
150 g_option_context_free (context);