[geary/mjog/search-update: 9/17] Geary.App.SearchFolder: Only update search if query is different
- From: Michael Gratton <mjog src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [geary/mjog/search-update: 9/17] Geary.App.SearchFolder: Only update search if query is different
- Date: Mon, 28 Dec 2020 09:33:40 +0000 (UTC)
commit c3139abafd24cd134e162a5525b2e5c77b8b7b3e
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]