[gnome-builder/wip/chergert/code-index-revamp: 14/16] code: add collect helper to avoid multiple calls
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-builder/wip/chergert/code-index-revamp: 14/16] code: add collect helper to avoid multiple calls
- Date: Sat, 2 Feb 2019 04:37:47 +0000 (UTC)
commit 3ac7a8846aa19393fe2b18bc8926c1ceaeb7cafc
Author: Christian Hergert <chergert redhat com>
Date: Fri Feb 1 20:33:37 2019 -0800
code: add collect helper to avoid multiple calls
src/libide/code/ide-code-index-entries.c | 90 ++++++++++++++++++++++++++++++++
src/libide/code/ide-code-index-entries.h | 9 ++++
2 files changed, 99 insertions(+)
---
diff --git a/src/libide/code/ide-code-index-entries.c b/src/libide/code/ide-code-index-entries.c
index aac522e97..68142a573 100644
--- a/src/libide/code/ide-code-index-entries.c
+++ b/src/libide/code/ide-code-index-entries.c
@@ -176,3 +176,93 @@ ide_code_index_entries_next_entries_finish (IdeCodeIndexEntries *self,
return IDE_CODE_INDEX_ENTRIES_GET_IFACE (self)->next_entries_finish (self, result, error);
}
+
+static void
+ide_code_index_entries_collect_cb (GObject *object,
+ GAsyncResult *result,
+ gpointer user_data)
+{
+ IdeCodeIndexEntries *self = (IdeCodeIndexEntries *)object;
+ g_autoptr(IdeTask) task = user_data;
+ g_autoptr(GPtrArray) ret = NULL;
+ g_autoptr(GError) error = NULL;
+ GPtrArray *task_data;
+
+ g_assert (IDE_IS_MAIN_THREAD ());
+ g_assert (IDE_IS_CODE_INDEX_ENTRIES (self));
+ g_assert (G_IS_ASYNC_RESULT (result));
+ g_assert (IDE_IS_TASK (task));
+
+ if (!(task_data = ide_task_get_task_data (task)))
+ {
+ task_data = g_ptr_array_new_with_free_func ((GDestroyNotify)ide_code_index_entry_free);
+ ide_task_set_task_data (task, task_data, g_ptr_array_unref);
+ }
+
+ if ((ret = ide_code_index_entries_next_entries_finish (self, result, &error)) && ret->len > 0)
+ {
+ IDE_PTR_ARRAY_SET_FREE_FUNC (ret, NULL);
+
+ for (guint i = 0; i < ret->len; i++)
+ g_ptr_array_add (task_data, g_ptr_array_index (ret, i));
+
+ g_ptr_array_remove_range (ret, 0, ret->len);
+
+ ide_code_index_entries_next_entries_async (self,
+ ide_task_get_cancellable (task),
+ ide_code_index_entries_collect_cb,
+ g_object_ref (task));
+ return;
+ }
+
+ ide_task_return_pointer (task,
+ g_ptr_array_ref (task_data),
+ (GDestroyNotify)g_ptr_array_unref);
+}
+
+/**
+ * ide_code_index_entries_collect_async:
+ *
+ * Calls ide_code_index_entries_next_entries_async() repeatedly until all
+ * entries have been retrieved. After that, the async operation will complete.
+ *
+ * Since: 3.32
+ */
+void
+ide_code_index_entries_collect_async (IdeCodeIndexEntries *self,
+ GCancellable *cancellable,
+ GAsyncReadyCallback callback,
+ gpointer user_data)
+{
+ g_autoptr(IdeTask) task = NULL;
+
+ g_return_if_fail (IDE_IS_CODE_INDEX_ENTRIES (self));
+ g_return_if_fail (!cancellable || G_IS_CANCELLABLE (cancellable));
+
+ task = ide_task_new (self, cancellable, callback, user_data);
+ ide_task_set_source_tag (task, ide_code_index_entries_collect_async);
+ ide_code_index_entries_next_entries_async (self,
+ cancellable,
+ ide_code_index_entries_collect_cb,
+ g_steal_pointer (&task));
+}
+
+/**
+ * ide_code_index_entries_collect_finish:
+ *
+ * Returns: (transfer full) (element-type IdeCodeIndexEntry): an array of #IdeCodeIndexEntry
+ * or %NULL and @error is set
+ *
+ * Since: 3.32
+ */
+GPtrArray *
+ide_code_index_entries_collect_finish (IdeCodeIndexEntries *self,
+ GAsyncResult *result,
+ GError **error)
+{
+ g_return_val_if_fail (IDE_IS_MAIN_THREAD (), NULL);
+ g_return_val_if_fail (IDE_IS_CODE_INDEX_ENTRIES (self), NULL);
+ g_return_val_if_fail (IDE_IS_TASK (result), NULL);
+
+ return ide_task_propagate_pointer (IDE_TASK (result), error);
+}
diff --git a/src/libide/code/ide-code-index-entries.h b/src/libide/code/ide-code-index-entries.h
index 176e36ab2..296a43aa8 100644
--- a/src/libide/code/ide-code-index-entries.h
+++ b/src/libide/code/ide-code-index-entries.h
@@ -64,5 +64,14 @@ IDE_AVAILABLE_IN_3_32
GPtrArray *ide_code_index_entries_next_entries_finish (IdeCodeIndexEntries *self,
GAsyncResult *result,
GError **error);
+IDE_AVAILABLE_IN_3_32
+void ide_code_index_entries_collect_async (IdeCodeIndexEntries *self,
+ GCancellable *cancellable,
+ GAsyncReadyCallback callback,
+ gpointer user_data);
+IDE_AVAILABLE_IN_3_32
+GPtrArray *ide_code_index_entries_collect_finish (IdeCodeIndexEntries *self,
+ GAsyncResult *result,
+ GError **error);
G_END_DECLS
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]