[geary/wip/geary-inspector: 14/19] Enable pausing/unpausing the log viewer



commit 2851c2dbd3566c672dad28a13a159cff8a9e733b
Author: Michael Gratton <mike vee net>
Date:   Sun Apr 7 16:11:26 2019 +1000

    Enable pausing/unpausing the log viewer

 src/client/components/components-inspector.vala | 68 +++++++++++++++++++------
 ui/components-inspector.ui                      | 20 ++++++++
 2 files changed, 72 insertions(+), 16 deletions(-)
---
diff --git a/src/client/components/components-inspector.vala b/src/client/components/components-inspector.vala
index bee621b3..67976d83 100644
--- a/src/client/components/components-inspector.vala
+++ b/src/client/components/components-inspector.vala
@@ -1,3 +1,4 @@
+
 /*
  * Copyright 2019 Michael Gratton <mike vee net>
  *
@@ -28,7 +29,10 @@ public class Components.Inspector : Gtk.Window {
     private Gtk.Widget logs_pane;
 
     [GtkChild]
-    private Gtk.Button search_button;
+    private Gtk.ToggleButton play_button;
+
+    [GtkChild]
+    private Gtk.ToggleButton search_button;
 
     [GtkChild]
     private Hdy.SearchBar search_bar;
@@ -61,6 +65,9 @@ public class Components.Inspector : Gtk.Window {
 
     private string details;
 
+    private bool update_logs = true;
+    private Geary.Logging.Record? first_pending = null;
+
     private bool autoscroll = true;
 
 
@@ -86,8 +93,13 @@ public class Components.Inspector : Gtk.Window {
         }
         this.details = details.str;
 
+        // Enable updates to get the log marker
         enable_log_updates(true);
 
+        // Install the listener then starting add the backlog
+        // (ba-doom-tish) so to avoid the race.
+        Geary.Logging.set_log_listener(this.on_log_record);
+
         Gtk.ListStore logs_store = this.logs_store;
         Geary.Logging.Record? logs = Geary.Logging.get_logs();
         int index = 0;
@@ -122,8 +134,6 @@ public class Components.Inspector : Gtk.Window {
     }
 
     public override void destroy() {
-        // Don't use enable_log_updates() here because we don't want a
-        // marker logged.
         Geary.Logging.set_log_listener(null);
         base.destroy();
     }
@@ -137,12 +147,26 @@ public class Components.Inspector : Gtk.Window {
     }
 
     private void enable_log_updates(bool enabled) {
-        // Log a marker it indicate when it was toggled
-        debug("---- 8< ---- %s ---- 8< ----", this.header_bar.title);
+        // Log a marker to indicate when it was started/stopped
+        debug(
+            "---- 8< ---- %s %s ---- 8< ----",
+            this.header_bar.title,
+            enabled ? "▶" : "■"
+        );
+
+        this.update_logs = enabled;
+
+        // Disable autoscroll when not updating as well to stop the
+        // tree view jumping to the bottom when changing the filter.
+        this.autoscroll = enabled;
+
         if (enabled) {
-            Geary.Logging.set_log_listener(this.on_log_record);
-        } else {
-            Geary.Logging.set_log_listener(null);
+            Geary.Logging.Record? logs = this.first_pending;
+            while (logs != null) {
+                append_record(logs);
+                logs = logs.get_next();
+            }
+            this.first_pending = null;
         }
     }
 
@@ -185,6 +209,7 @@ public class Components.Inspector : Gtk.Window {
         bool logs_visible = this.stack.visible_child == this.logs_pane;
         uint logs_selected = this.logs_view.get_selection().count_selected_rows();
         this.copy_button.set_sensitive(!logs_visible || logs_selected > 0);
+        this.play_button.set_visible(logs_visible);
         this.search_button.set_visible(logs_visible);
     }
 
@@ -284,20 +309,31 @@ public class Components.Inspector : Gtk.Window {
         update_ui();
     }
 
+    [GtkCallback]
+    private void on_logs_play_toggled(Gtk.ToggleButton button) {
+        if (this.update_logs != button.active) {
+            enable_log_updates(button.active);
+        }
+    }
+
     [GtkCallback]
     private void on_logs_search_changed() {
         update_logs_filter();
     }
 
     private void on_log_record(Geary.Logging.Record record) {
-        if (GLib.MainContext.default() ==
-            GLib.MainContext.get_thread_default()) {
-            append_record(record);
-        } else {
-            GLib.Idle.add(() => {
-                    append_record(record);
-                    return GLib.Source.REMOVE;
-                });
+        if (this.update_logs) {
+            if (GLib.MainContext.default() ==
+                GLib.MainContext.get_thread_default()) {
+                append_record(record);
+            } else {
+                GLib.Idle.add(() => {
+                        append_record(record);
+                        return GLib.Source.REMOVE;
+                    });
+            }
+        } else if (this.first_pending == null) {
+            this.first_pending = record;
         }
     }
 
diff --git a/ui/components-inspector.ui b/ui/components-inspector.ui
index e9552e34..d138ade8 100644
--- a/ui/components-inspector.ui
+++ b/ui/components-inspector.ui
@@ -23,6 +23,23 @@
         <property name="visible">True</property>
         <property name="can_focus">False</property>
         <property name="show_close_button">True</property>
+        <child>
+          <object class="GtkToggleButton" id="play_button">
+            <property name="visible">True</property>
+            <property name="can_focus">True</property>
+            <property name="receives_default">True</property>
+            <property name="tooltip_text" translatable="yes" comments="Tooltip for inspector button">Togggle 
appending new log entries</property>
+            <property name="active">True</property>
+            <signal name="toggled" handler="on_logs_play_toggled" swapped="no"/>
+            <child>
+              <object class="GtkImage">
+                <property name="visible">True</property>
+                <property name="can_focus">False</property>
+                <property name="icon_name">media-playback-start-symbolic</property>
+              </object>
+            </child>
+          </object>
+        </child>
         <child>
           <object class="GtkButton" id="search_button">
             <property name="visible">True</property>
@@ -38,6 +55,9 @@
               </object>
             </child>
           </object>
+          <packing>
+            <property name="position">1</property>
+          </packing>
         </child>
         <child type="title">
           <object class="GtkStackSwitcher">


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