[tor-commits] [nyx/master] Use draw() for log panel

atagar at torproject.org atagar at torproject.org
Mon Jul 4 22:27:02 UTC 2016


commit b67eca1920e448774d71f9bf7df5117748259d7a
Author: Damian Johnson <atagar at torproject.org>
Date:   Sun Jun 26 11:50:34 2016 -0700

    Use draw() for log panel
---
 nyx/curses.py         | 50 ++++++++++++++++++++++++++++++++++++++++++++++++++
 nyx/panel/__init__.py |  2 +-
 nyx/panel/log.py      | 36 ++++++++++++++++++------------------
 3 files changed, 69 insertions(+), 19 deletions(-)

diff --git a/nyx/curses.py b/nyx/curses.py
index a02adc8..1c36526 100644
--- a/nyx/curses.py
+++ b/nyx/curses.py
@@ -612,6 +612,56 @@ class _Subwindow(object):
     self._addch(left + width - 1, top, curses.ACS_URCORNER, *attr)  # upper right corner
     self._addch(left + width - 1, top + height - 1, curses.ACS_LRCORNER, *attr)  # lower right corner
 
+  def scrollbar(self, top, top_index, size):
+    """
+    Draws a left justified scrollbar reflecting position within a vertical
+    listing. The bottom is squared off, having a layout like:
+
+    ::
+
+      -+---------------------------
+       | lovely content we're
+      *| showing in the window
+      *|
+      *|
+       |
+      -+
+
+    :param int top: top row in the subwindow where the scrollbar should be drawn
+    :param int top_index: list index for the top-most visible element
+    :param int size: size of the list in which the listed elements are contained
+    """
+
+    if (self.height - top) < 2:
+      return  # not enough room
+
+    # determines scrollbar dimensions
+
+    scrollbar_height = self.height - top - 1
+    bottom_index = top_index + scrollbar_height
+    slider_top = scrollbar_height * top_index / size
+    slider_size = scrollbar_height * (bottom_index - top_index) / size
+    max_slider_top = scrollbar_height - slider_size - 1
+
+    # ensures slider isn't at top or bottom unless really at those extreme bounds
+
+    slider_top = 0 if top_index == 0 else max(slider_top, 1)
+    slider_top = max_slider_top if bottom_index == size else min(slider_top, max_slider_top - 1)
+
+    # draws scrollbar slider
+
+    for i in range(scrollbar_height):
+      if i >= slider_top and i <= slider_top + slider_size:
+        self.addstr(0, i + top, ' ', Attr.HIGHLIGHT)
+      else:
+        self.addstr(0, i + top, ' ')
+
+    # draws box around the scrollbar
+
+    self.vline(1, top, self.height - 2)
+    self._addch(1, self.height - 1, curses.ACS_LRCORNER)
+    self._addch(0, self.height - 1, curses.ACS_HLINE)
+
   def _addch(self, x, y, char, *attr):
     if self.width > x and self.height > y:
       try:
diff --git a/nyx/panel/__init__.py b/nyx/panel/__init__.py
index 6c77ea9..4784292 100644
--- a/nyx/panel/__init__.py
+++ b/nyx/panel/__init__.py
@@ -266,7 +266,7 @@ class Panel(object):
     if not self.visible or HALT_ACTIVITY:
       return
 
-    if self.panel_name in ('header', 'graph'):
+    if self.panel_name in ('header', 'graph', 'log'):
       height = self.get_height() if self.get_height() != -1 else None
       width = self.get_width() if self.get_width() != -1 else None
 
diff --git a/nyx/panel/log.py b/nyx/panel/log.py
index 9de7353..5c7e60b 100644
--- a/nyx/panel/log.py
+++ b/nyx/panel/log.py
@@ -252,8 +252,8 @@ class LogPanel(nyx.panel.DaemonPanel):
 
     nyx.panel.Panel.set_paused(self, is_pause)
 
-  def draw(self, width, height):
-    scroll = self._scroller.location(self._last_content_height, height)
+  def draw(self, subwindow):
+    scroll = self._scroller.location(self._last_content_height, subwindow.height)
 
     event_log = list(self._event_log_paused if self.is_paused() else self._event_log)
     event_filter = self._filter.clone()
@@ -261,10 +261,10 @@ class LogPanel(nyx.panel.DaemonPanel):
     last_content_height = self._last_content_height
     show_duplicates = self._show_duplicates
 
-    is_scrollbar_visible = last_content_height > height - 1
+    is_scrollbar_visible = last_content_height > subwindow.height - 1
 
     if is_scrollbar_visible:
-      self.add_scroll_bar(scroll, scroll + height - 1, last_content_height, 1)
+      subwindow.scrollbar(1, scroll, last_content_height)
 
     x, y = 3 if is_scrollbar_visible else 1, 1 - scroll
 
@@ -283,22 +283,22 @@ class LogPanel(nyx.panel.DaemonPanel):
     for day in sorted(day_to_entries.keys(), reverse = True):
       if day == today:
         for entry in day_to_entries[day]:
-          y = self._draw_entry(x, y, width, entry, show_duplicates)
+          y = self._draw_entry(subwindow, x, y, subwindow.width, entry, show_duplicates)
       else:
         original_y, y = y, y + 1
 
         for entry in day_to_entries[day]:
-          y = self._draw_entry(x, y, width, entry, show_duplicates)
+          y = self._draw_entry(subwindow, x, y, subwindow.width, entry, show_duplicates)
 
-        self.draw_box(original_y, x - 1, width - x + 1, y - original_y + 1, YELLOW, BOLD)
+        subwindow.box(original_y, x - 1, subwindow.width - x + 1, y - original_y + 1, YELLOW, BOLD)
         time_label = time.strftime(' %B %d, %Y ', time.localtime(day_to_entries[day][0].timestamp))
-        self.addstr(original_y, x + 1, time_label, YELLOW, BOLD)
+        subwindow.addstr(x + 1, original_y, time_label, YELLOW, BOLD)
 
         y += 1
 
     # drawing the title after the content, so we'll clear content from the top line
 
-    self._draw_title(width, event_types, event_filter)
+    self._draw_title(subwindow, subwindow.width, event_types, event_filter)
 
     # redraw the display if...
     # - last_content_height was off by too much
@@ -310,11 +310,11 @@ class LogPanel(nyx.panel.DaemonPanel):
 
     if content_height_delta >= CONTENT_HEIGHT_REDRAW_THRESHOLD:
       force_redraw_reason = 'estimate was off by %i' % content_height_delta
-    elif new_content_height > height and scroll + height - 1 > new_content_height:
+    elif new_content_height > subwindow.height and scroll + subwindow.height - 1 > new_content_height:
       force_redraw_reason = 'scrolled off the bottom of the page'
-    elif not is_scrollbar_visible and new_content_height > height - 1:
+    elif not is_scrollbar_visible and new_content_height > subwindow.height - 1:
       force_redraw_reason = "scroll bar wasn't previously visible"
-    elif is_scrollbar_visible and new_content_height <= height - 1:
+    elif is_scrollbar_visible and new_content_height <= subwindow.height - 1:
       force_redraw_reason = "scroll bar shouldn't be visible"
     else:
       force_redraw = False
@@ -326,12 +326,12 @@ class LogPanel(nyx.panel.DaemonPanel):
       log.debug('redrawing the log panel with the corrected content height (%s)' % force_redraw_reason)
       self.redraw(True)
 
-  def _draw_title(self, width, event_types, event_filter):
+  def _draw_title(self, subwindow, width, event_types, event_filter):
     """
     Panel title with the event types we're logging and our regex filter if set.
     """
 
-    self.addstr(0, 0, ' ' * width)  # clear line
+    subwindow.addstr(0, 0, ' ' * width)  # clear line
     title_comp = list(nyx.log.condense_runlevels(*event_types))
 
     if event_filter.selection():
@@ -340,9 +340,9 @@ class LogPanel(nyx.panel.DaemonPanel):
     title_comp_str = join(title_comp, ', ', width - 10)
     title = 'Events (%s):' % title_comp_str if title_comp_str else 'Events:'
 
-    self.addstr(0, 0, title, HIGHLIGHT)
+    subwindow.addstr(0, 0, title, HIGHLIGHT)
 
-  def _draw_entry(self, x, y, width, entry, show_duplicates):
+  def _draw_entry(self, subwindow, x, y, width, entry, show_duplicates):
     """
     Presents a log entry with line wrapping.
     """
@@ -352,13 +352,13 @@ class LogPanel(nyx.panel.DaemonPanel):
     color = CONFIG['attr.log_color'].get(entry.type, WHITE)
 
     for line in msg.splitlines():
-      x, y = self.addstr_wrap(y, x, line, width, min_x, boldness, color)
+      x, y = subwindow.addstr_wrap(x, y, line, width, min_x, boldness, color)
 
     if entry.duplicates and not show_duplicates:
       duplicate_count = len(entry.duplicates) - 1
       plural = 's' if duplicate_count > 1 else ''
       duplicate_msg = ' [%i duplicate%s hidden]' % (duplicate_count, plural)
-      x, y = self.addstr_wrap(y, x, duplicate_msg, width, min_x, GREEN, BOLD)
+      x, y = subwindow.addstr_wrap(x, y, duplicate_msg, width, min_x, GREEN, BOLD)
 
     return y + 1
 





More information about the tor-commits mailing list