From 4ba34702693607f4d6dd5133664dd950b2ce5220 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 21 Mar 2023 10:29:29 +0000 Subject: [PATCH 1/3] gio: Add some missing file info attribute checks in gio-list and gio-tree Further fallout from #2907. Signed-off-by: Philip Withnall Fixes: #2948 --- gio/gio-tool-info.c | 6 ++++-- gio/gio-tool-list.c | 9 ++++++--- gio/gio-tool-tree.c | 11 ++++++++--- 3 files changed, 18 insertions(+), 8 deletions(-) diff --git a/gio/gio-tool-info.c b/gio/gio-tool-info.c index d51edb47b..749bd2d13 100644 --- a/gio/gio-tool-info.c +++ b/gio/gio-tool-info.c @@ -157,7 +157,8 @@ show_info (GFile *file, GFileInfo *info) GUnixMountEntry *entry; #endif - name = g_file_info_get_display_name (info); + name = g_file_info_has_attribute (info, G_FILE_ATTRIBUTE_STANDARD_DISPLAY_NAME) ? + g_file_info_get_display_name (info) : NULL; if (name) { /* Translators: This is a noun and represents and attribute of a file */ @@ -166,7 +167,8 @@ show_info (GFile *file, GFileInfo *info) g_free (flatten); } - name = g_file_info_get_edit_name (info); + name = g_file_info_has_attribute (info, G_FILE_ATTRIBUTE_STANDARD_EDIT_NAME) ? + g_file_info_get_edit_name (info) : NULL; if (name) { /* Translators: This is a noun and represents and attribute of a file */ diff --git a/gio/gio-tool-list.c b/gio/gio-tool-list.c index 24e3dac3c..0da86269d 100644 --- a/gio/gio-tool-list.c +++ b/gio/gio-tool-list.c @@ -54,10 +54,12 @@ show_file_listing (GFileInfo *info, GFile *parent) gboolean first_attr; GFile *child; - if ((g_file_info_get_is_hidden (info)) && !show_hidden) + if (g_file_info_has_attribute (info, G_FILE_ATTRIBUTE_STANDARD_IS_HIDDEN) && + g_file_info_get_is_hidden (info) && + !show_hidden) return; - if (print_display_names) + if (print_display_names && g_file_info_has_attribute (info, G_FILE_ATTRIBUTE_STANDARD_DISPLAY_NAME)) name = g_file_info_get_display_name (info); else name = g_file_info_get_name (info); @@ -71,7 +73,8 @@ show_file_listing (GFileInfo *info, GFile *parent) g_object_unref (child); } - size = g_file_info_get_size (info); + size = g_file_info_has_attribute (info, G_FILE_ATTRIBUTE_STANDARD_SIZE) ? + g_file_info_get_size (info) : 0; type = file_type_to_string (g_file_info_get_file_type (info)); if (show_long) g_print ("%s\t%"G_GUINT64_FORMAT"\t(%s)", print_uris? uri: name, (guint64)size, type); diff --git a/gio/gio-tool-tree.c b/gio/gio-tool-tree.c index 071588240..28fad051f 100644 --- a/gio/gio-tool-tree.c +++ b/gio/gio-tool-tree.c @@ -95,7 +95,9 @@ do_tree (GFile *f, unsigned int level, guint64 pattern) info_list = NULL; while ((info = g_file_enumerator_next_file (enumerator, NULL, NULL)) != NULL) { - if (g_file_info_get_is_hidden (info) && !show_hidden) + if (g_file_info_has_attribute (info, G_FILE_ATTRIBUTE_STANDARD_IS_HIDDEN) && + g_file_info_get_is_hidden (info) && + !show_hidden) { g_object_unref (info); } @@ -151,7 +153,8 @@ do_tree (GFile *f, unsigned int level, guint64 pattern) } else { - if (g_file_info_get_is_symlink (info)) + if (g_file_info_has_attribute (info, G_FILE_ATTRIBUTE_STANDARD_IS_SYMLINK) && + g_file_info_get_is_symlink (info)) { const char *target; target = g_file_info_get_symlink_target (info); @@ -162,7 +165,9 @@ do_tree (GFile *f, unsigned int level, guint64 pattern) g_print ("\n"); if ((type & G_FILE_TYPE_DIRECTORY) && - (follow_symlinks || !g_file_info_get_is_symlink (info))) + (follow_symlinks || + !(g_file_info_has_attribute (info, G_FILE_ATTRIBUTE_STANDARD_IS_SYMLINK) && + g_file_info_get_is_symlink (info)))) { guint64 new_pattern; GFile *child; From 2029d7e900b575aef493593b4ed0cd38bbc5a965 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 21 Mar 2023 11:15:31 +0000 Subject: [PATCH 2/3] gpollfilemonitor: Add missing attribute checks for g_file_info_get_size() Missed from the fixes for #2907. Signed-off-by: Philip Withnall --- gio/gpollfilemonitor.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/gio/gpollfilemonitor.c b/gio/gpollfilemonitor.c index c4dfd9913..2a8473630 100644 --- a/gio/gpollfilemonitor.c +++ b/gio/gpollfilemonitor.c @@ -94,7 +94,9 @@ calc_event_type (GFileInfo *last, g_strcmp0 (g_file_info_get_etag (last), g_file_info_get_etag (new)) != 0) return G_FILE_MONITOR_EVENT_CHANGED; - if (g_file_info_get_size (last) != g_file_info_get_size (new)) + if (g_file_info_has_attribute (last, G_FILE_ATTRIBUTE_STANDARD_SIZE) && + g_file_info_has_attribute (new, G_FILE_ATTRIBUTE_STANDARD_SIZE) && + g_file_info_get_size (last) != g_file_info_get_size (new)) return G_FILE_MONITOR_EVENT_CHANGED; return -1; From 2953c082617a6ed72fcc87d91d4323f551836a4d Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Tue, 21 Mar 2023 12:11:38 +0000 Subject: [PATCH 3/3] gfileinfo: Zero GTimeVal when failing g_file_info_get_modification_time() MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Before commit ed8e86a7d4, this function would have silently returned a zero-valued `GTimeVal` if the correct attributes weren’t present. That partially regressed in commit ed8e86a7d4, which made it return with a critical warning, but without zeroing the `GTimeVal`. The critical warning can be ignored by users (it doesn’t abort the process unless `G_DEBUG=fatal-criticals` is set), but the change in behaviour of zeroing the `GTimeVal` could cause bugs. See: #2907 Signed-off-by: Philip Withnall --- gio/gfileinfo.c | 1 + 1 file changed, 1 insertion(+) diff --git a/gio/gfileinfo.c b/gio/gfileinfo.c index ad196d0ec..ca42add8e 100644 --- a/gio/gfileinfo.c +++ b/gio/gfileinfo.c @@ -1838,6 +1838,7 @@ g_file_info_get_modification_time (GFileInfo *info, if (G_UNLIKELY (value == NULL)) { g_critical ("GFileInfo created without " G_FILE_ATTRIBUTE_TIME_MODIFIED); + result->tv_sec = result->tv_usec = 0; g_return_if_reached (); }