IDE: Log: Cosmetic changes, refactoring
authorEdouard Tisserant <edouard.tisserant@gmail.com>
Tue, 02 Mar 2021 09:25:55 +0100 (2021-03-02)
changeset 2728 10d8ca7a3d31
parent 2727 6330e6bb345d
child 2729 4e0cd7806776
IDE: Log: Cosmetic changes, refactoring
BeremizIDE.py
--- a/BeremizIDE.py	Mon Mar 01 15:45:13 2021 +0100
+++ b/BeremizIDE.py	Tue Mar 02 09:25:55 2021 +0100
@@ -122,7 +122,7 @@
         self.risecall = risecall
         # to prevent rapid fire on rising log panel
         self.rising_timer = 0
-        self.lock = Lock()
+        self.StackLock = Lock()
         self.YieldLock = Lock()
         self.RefreshLock = Lock()
         self.TimerAccessLock = Lock()
@@ -131,22 +131,22 @@
         self.LastRefreshTimer = None
 
     def write(self, s, style=None):
-        if self.lock.acquire():
-            self.stack.append((s, style))
-            self.lock.release()
-            current_time = gettime()
+        self.StackLock.acquire()
+        self.stack.append((s, style))
+        self.StackLock.release()
+        current_time = gettime()
+        with self.TimerAccessLock:
+            if self.LastRefreshTimer is not None:
+                self.LastRefreshTimer.cancel()
+                self.LastRefreshTimer = None
+        elapsed = current_time - self.LastRefreshTime
+        if elapsed > REFRESH_PERIOD:
+            self._should_write()
+        else:
             with self.TimerAccessLock:
-                if self.LastRefreshTimer is not None:
-                    self.LastRefreshTimer.cancel()
-                    self.LastRefreshTimer = None
-            elapsed = current_time - self.LastRefreshTime
-            if elapsed > REFRESH_PERIOD:
-                self._should_write()
-            else:
-                with self.TimerAccessLock:
-                    if self.LastRefreshTimer is None:
-                        self.LastRefreshTimer = Timer(REFRESH_PERIOD - elapsed, self._timer_expired)
-                        self.LastRefreshTimer.start()
+                if self.LastRefreshTimer is None:
+                    self.LastRefreshTimer = Timer(REFRESH_PERIOD - elapsed, self._timer_expired)
+                    self.LastRefreshTimer.start()
 
     def _timer_expired(self):
         self._should_write()
@@ -171,7 +171,8 @@
         if self.output:
             with self.RefreshLock:
                 self.output.Freeze()
-                self.lock.acquire()
+                self.output.AnnotationClearAll()
+                self.StackLock.acquire()
                 for s, style in self.stack:
                     if style is None:
                         style = self.black_white
@@ -191,7 +192,7 @@
                     if style != self.black_white:
                         self.output.SetStyling(text_len, style)
                 self.stack = []
-                self.lock.release()
+                self.StackLock.release()
                 self.output.Thaw()
                 self.LastRefreshTime = gettime()
                 newtime = time.time()