[nautilus/menial-but-very-rewarding-work-that-made-my-fingers-numb: 2/7] eel: glib-extensions: Move functions to Nautilus
- From: Carlos Soriano <csoriano src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [nautilus/menial-but-very-rewarding-work-that-made-my-fingers-numb: 2/7] eel: glib-extensions: Move functions to Nautilus
- Date: Fri, 18 May 2018 14:07:30 +0000 (UTC)
commit 2302743fe59bf05d9b18dad0a254f13d817c6d8b
Author: Ernestas Kulik <ernestask gnome org>
Date: Fri May 18 14:16:19 2018 +0300
eel: glib-extensions: Move functions to Nautilus
They’re only used once, so why not.
eel/eel-glib-extensions.c | 105 ----------------------------------------------
eel/eel-glib-extensions.h | 8 ----
eel/meson.build | 1 -
src/nautilus-file.c | 22 +++++++++-
src/nautilus-files-view.c | 52 ++++++++++++++++++++++-
5 files changed, 72 insertions(+), 116 deletions(-)
---
diff --git a/eel/eel-glib-extensions.h b/eel/eel-glib-extensions.h
index 8b09cbd10..3b0ea0dfc 100644
--- a/eel/eel-glib-extensions.h
+++ b/eel/eel-glib-extensions.h
@@ -28,11 +28,3 @@
/* A gboolean variant for bit fields. */
typedef guint eel_boolean_bit;
-
-/* GList functions. */
-gboolean eel_g_lists_sort_and_check_for_intersection (GList **list_a,
- GList **list_b);
-
-/* NULL terminated string arrays (strv). */
-gboolean eel_g_strv_equal (char **a,
- char **b);
\ No newline at end of file
diff --git a/eel/meson.build b/eel/meson.build
index 2f577a981..ba06203d4 100644
--- a/eel/meson.build
+++ b/eel/meson.build
@@ -8,7 +8,6 @@ libeel_2_sources = [
'eel-debug.h',
'eel-debug.c',
'eel-glib-extensions.h',
- 'eel-glib-extensions.c',
'eel-graphic-effects.h',
'eel-graphic-effects.c',
'eel-gtk-extensions.h',
diff --git a/src/nautilus-file.c b/src/nautilus-file.c
index d3ba8c841..a735fc0f0 100644
--- a/src/nautilus-file.c
+++ b/src/nautilus-file.c
@@ -329,6 +329,26 @@ metadata_hash_free (GHashTable *hash)
g_hash_table_destroy (hash);
}
+static gboolean
+_g_strv_equal (GStrv a,
+ GStrv b)
+{
+ if (g_strv_length (a) != g_strv_length (b))
+ {
+ return FALSE;
+ }
+
+ for (int i = 0; a[i] != NULL; i++)
+ {
+ if (strcmp (a[i], b[i]) != 0)
+ {
+ return FALSE;
+ }
+ }
+
+ return TRUE;
+}
+
static gboolean
metadata_hash_equal (GHashTable *hash1,
GHashTable *hash2)
@@ -364,7 +384,7 @@ metadata_hash_equal (GHashTable *hash1,
id = GPOINTER_TO_UINT (key1);
if (id & METADATA_ID_IS_LIST_MASK)
{
- if (!eel_g_strv_equal ((char **) value1, (char **) value2))
+ if (!_g_strv_equal ((char **) value1, (char **) value2))
{
return FALSE;
}
diff --git a/src/nautilus-files-view.c b/src/nautilus-files-view.c
index 5b6aae8ff..9f6eabde7 100644
--- a/src/nautilus-files-view.c
+++ b/src/nautilus-files-view.c
@@ -4029,6 +4029,56 @@ on_end_file_changes (NautilusFilesView *view)
}
}
+static int
+compare_pointers (gconstpointer pointer_1,
+ gconstpointer pointer_2)
+{
+ if (pointer_1 < pointer_2)
+ {
+ return -1;
+ }
+ else if (pointer_1 > pointer_2)
+ {
+ return +1;
+ }
+
+ return 0;
+}
+
+static gboolean
+_g_lists_sort_and_check_for_intersection (GList **list_1,
+ GList **list_2)
+{
+ GList *node_1;
+ GList *node_2;
+ int compare_result;
+
+ *list_1 = g_list_sort (*list_1, compare_pointers);
+ *list_2 = g_list_sort (*list_2, compare_pointers);
+
+ node_1 = *list_1;
+ node_2 = *list_2;
+
+ while (node_1 != NULL && node_2 != NULL)
+ {
+ compare_result = compare_pointers (node_1->data, node_2->data);
+ if (compare_result == 0)
+ {
+ return TRUE;
+ }
+ if (compare_result <= 0)
+ {
+ node_1 = node_1->next;
+ }
+ if (compare_result >= 0)
+ {
+ node_2 = node_2->next;
+ }
+ }
+
+ return FALSE;
+}
+
static void
process_old_files (NautilusFilesView *view)
{
@@ -4099,7 +4149,7 @@ process_old_files (NautilusFilesView *view)
g_autolist (NautilusFile) selection = NULL;
selection = nautilus_view_get_selection (NAUTILUS_VIEW (view));
files = file_and_directory_list_to_files (files_changed);
- send_selection_change = eel_g_lists_sort_and_check_for_intersection
+ send_selection_change = _g_lists_sort_and_check_for_intersection
(&files, &selection);
nautilus_file_list_free (files);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]