[geary/mjog/search-update: 25/29] Geary.App.SearchFolder: Only update search if query is different




commit a0f308c500dd9f6652996e69250ddbce7298e240
Author: Michael Gratton <mike vee net>
Date:   Thu Nov 5 00:49:57 2020 +1100

    Geary.App.SearchFolder: Only update search if query is different
    
    This prevents re-running a search for e.g. whitespace-only changes.

 src/engine/app/app-search-folder.vala | 34 ++++++++++++++++++----------------
 1 file changed, 18 insertions(+), 16 deletions(-)
---
diff --git a/src/engine/app/app-search-folder.vala b/src/engine/app/app-search-folder.vala
index 0ad7552f2..981cb5a79 100644
--- a/src/engine/app/app-search-folder.vala
+++ b/src/engine/app/app-search-folder.vala
@@ -153,27 +153,29 @@ public class Geary.App.SearchFolder :
      */
     public async void search(SearchQuery query, GLib.Cancellable? cancellable)
         throws GLib.Error {
-        int result_mutex_token = yield result_mutex.claim_async();
+        if (this.query == null || !this.query.equal_to(query)) {
+            int result_mutex_token = yield result_mutex.claim_async();
 
-        clear();
+            clear();
 
-        if (cancellable != null) {
-            GLib.Cancellable @internal = this.executing;
-            cancellable.cancelled.connect(() => { @internal.cancel(); });
-        }
+            if (cancellable != null) {
+                GLib.Cancellable @internal = this.executing;
+                cancellable.cancelled.connect(() => { @internal.cancel(); });
+            }
 
-        this.query = query;
-        GLib.Error? error = null;
-        try {
-            yield do_search_async(null, null, this.executing);
-        } catch(Error e) {
-            error = e;
-        }
+            this.query = query;
+            GLib.Error? error = null;
+            try {
+                yield do_search_async(null, null, this.executing);
+            } catch(Error e) {
+                error = e;
+            }
 
-        result_mutex.release(ref result_mutex_token);
+            result_mutex.release(ref result_mutex_token);
 
-        if (error != null) {
-            throw error;
+            if (error != null) {
+                throw error;
+            }
         }
     }
 


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]