glocalfile: Improve wording for error messages about trash directories

Signed-off-by: Philip Withnall <pwithnall@endlessos.org>

Fixes: #1283
This commit is contained in:
Philip Withnall 2020-12-22 18:22:50 +00:00
parent 8cec87ff46
commit 7f2af262bf

View File

@ -2038,6 +2038,7 @@ g_local_file_trash (GFile *file,
{ {
uid_t uid; uid_t uid;
char uid_str[32]; char uid_str[32];
gboolean success;
uid = geteuid (); uid = geteuid ();
g_snprintf (uid_str, sizeof (uid_str), "%lu", (unsigned long)uid); g_snprintf (uid_str, sizeof (uid_str), "%lu", (unsigned long)uid);
@ -2093,6 +2094,7 @@ g_local_file_trash (GFile *file,
/* No global trash dir, or it failed the tests, fall back to $topdir/.Trash-$uid */ /* No global trash dir, or it failed the tests, fall back to $topdir/.Trash-$uid */
dirname = g_strdup_printf (".Trash-%s", uid_str); dirname = g_strdup_printf (".Trash-%s", uid_str);
trashdir = g_build_filename (topdir, dirname, NULL); trashdir = g_build_filename (topdir, dirname, NULL);
success = TRUE;
g_free (dirname); g_free (dirname);
tried_create = FALSE; tried_create = FALSE;
@ -2108,8 +2110,7 @@ g_local_file_trash (GFile *file,
g_remove (trashdir); g_remove (trashdir);
/* Not a directory or not owned by user, ignore */ /* Not a directory or not owned by user, ignore */
g_free (trashdir); success = FALSE;
trashdir = NULL;
} }
} }
else else
@ -2124,18 +2125,28 @@ g_local_file_trash (GFile *file,
} }
else else
{ {
g_free (trashdir); success = FALSE;
trashdir = NULL;
} }
} }
} }
if (trashdir == NULL) if (!success)
{ {
gchar *trashdir_display_name = NULL, *file_display_name = NULL;
trashdir_display_name = g_filename_display_name (trashdir);
file_display_name = g_filename_display_name (local->filename);
g_set_error (error, G_IO_ERROR,
G_IO_ERROR_NOT_SUPPORTED,
_("Unable to find or create trash directory %s to trash %s"),
trashdir_display_name, file_display_name);
g_free (trashdir_display_name);
g_free (file_display_name);
g_free (topdir); g_free (topdir);
g_set_io_error (error, g_free (trashdir);
_("Unable to find or create trash directory for %s"),
file, G_IO_ERROR_NOT_SUPPORTED);
return FALSE; return FALSE;
} }
} }
@ -2144,21 +2155,33 @@ g_local_file_trash (GFile *file,
infodir = g_build_filename (trashdir, "info", NULL); infodir = g_build_filename (trashdir, "info", NULL);
filesdir = g_build_filename (trashdir, "files", NULL); filesdir = g_build_filename (trashdir, "files", NULL);
g_free (trashdir);
/* Make sure we have the subdirectories */ /* Make sure we have the subdirectories */
if ((g_mkdir (infodir, 0700) == -1 && errno != EEXIST) || if ((g_mkdir (infodir, 0700) == -1 && errno != EEXIST) ||
(g_mkdir (filesdir, 0700) == -1 && errno != EEXIST)) (g_mkdir (filesdir, 0700) == -1 && errno != EEXIST))
{ {
gchar *trashdir_display_name = NULL, *file_display_name = NULL;
trashdir_display_name = g_filename_display_name (trashdir);
file_display_name = g_filename_display_name (local->filename);
g_set_error (error, G_IO_ERROR,
G_IO_ERROR_NOT_SUPPORTED,
_("Unable to find or create trash directory %s to trash %s"),
trashdir_display_name, file_display_name);
g_free (trashdir_display_name);
g_free (file_display_name);
g_free (topdir); g_free (topdir);
g_free (trashdir);
g_free (infodir); g_free (infodir);
g_free (filesdir); g_free (filesdir);
g_set_io_error (error,
_("Unable to find or create trash directory for %s"),
file, G_IO_ERROR_NOT_SUPPORTED);
return FALSE; return FALSE;
} }
g_free (trashdir);
basename = g_path_get_basename (local->filename); basename = g_path_get_basename (local->filename);
i = 1; i = 1;
trashname = NULL; trashname = NULL;