aboutsummaryrefslogtreecommitdiff
path: root/fastiv.c
diff options
context:
space:
mode:
authorPřemysl Eric Janouch <p@janouch.name>2021-12-19 09:07:14 +0100
committerPřemysl Eric Janouch <p@janouch.name>2021-12-19 09:12:06 +0100
commit9feb53a792b49ec3547d4678d18e7af23c2f064f (patch)
treed45e1e50ffa32bc13cb0f6164e0f7d650ca174d0 /fastiv.c
parent4427da534304d8e9adba8bfed2edb1097f51ad3e (diff)
downloadfiv-9feb53a792b49ec3547d4678d18e7af23c2f064f.tar.gz
fiv-9feb53a792b49ec3547d4678d18e7af23c2f064f.tar.xz
fiv-9feb53a792b49ec3547d4678d18e7af23c2f064f.zip
Use the same iteration order in view/browser
Diffstat (limited to 'fastiv.c')
-rw-r--r--fastiv.c56
1 files changed, 37 insertions, 19 deletions
diff --git a/fastiv.c b/fastiv.c
index 606b133..c967364 100644
--- a/fastiv.c
+++ b/fastiv.c
@@ -174,6 +174,35 @@ switch_to_view(const char *path)
gtk_widget_grab_focus(g.view);
}
+static gint
+files_compare(gconstpointer a, gconstpointer b)
+{
+ gchar *path1 = g_canonicalize_filename(*(gchar **) a, g.directory);
+ gchar *path2 = g_canonicalize_filename(*(gchar **) b, g.directory);
+ GFile *location1 = g_file_new_for_path(path1);
+ GFile *location2 = g_file_new_for_path(path2);
+ g_free(path1);
+ g_free(path2);
+ gint result = fiv_io_filecmp(location1, location2);
+ g_object_unref(location1);
+ g_object_unref(location2);
+ return result;
+}
+
+static void
+update_files_index(void)
+{
+ g.files_index = -1;
+
+ // FIXME: We presume that this basename is from the same directory.
+ gchar *basename = g.path ? g_path_get_basename(g.path) : NULL;
+ for (guint i = 0; i < g.files->len; i++) {
+ if (!g_strcmp0(basename, g_ptr_array_index(g.files, i)))
+ g.files_index = i;
+ }
+ g_free(basename);
+}
+
static void
load_directory(const gchar *dirname)
{
@@ -204,18 +233,13 @@ load_directory(const gchar *dirname)
char *absolute = g_canonicalize_filename(name, g.directory);
gboolean is_dir = g_file_test(absolute, G_FILE_TEST_IS_DIR);
g_free(absolute);
- if (is_dir || !is_supported(name))
- continue;
-
- // FIXME: We presume that this basename is from the same directory.
- gchar *basename = g.path ? g_path_get_basename(g.path) : NULL;
- if (!g_strcmp0(basename, name))
- g.files_index = g.files->len;
- g_free(basename);
-
- g_ptr_array_add(g.files, g_strdup(name));
+ if (!is_dir && is_supported(name))
+ g_ptr_array_add(g.files, g_strdup(name));
}
g_dir_close(dir);
+
+ g_ptr_array_sort(g.files, files_compare);
+ update_files_index();
} else {
show_error_dialog(error);
}
@@ -262,16 +286,10 @@ open(const gchar *path)
// So that load_directory() itself can be used for reloading.
gchar *dirname = g_path_get_dirname(path);
if (!g.files->len /* hack to always load the directory after launch */ ||
- !g.directory || strcmp(dirname, g.directory)) {
+ !g.directory || strcmp(dirname, g.directory))
load_directory(dirname);
- } else {
- g.files_index = -1;
- gchar *basename = g_path_get_basename(g.path);
- for (guint i = 0; i + 1 < g.files->len; i++)
- if (!g_strcmp0(basename, g_ptr_array_index(g.files, i)))
- g.files_index = i;
- g_free(basename);
- }
+ else
+ update_files_index();
g_free(dirname);
switch_to_view(path);