Add ranged line omission feature

This commit is contained in:
René Stadler 2007-11-27 16:50:41 +02:00 committed by Stefan Sauer
parent cb6d082f19
commit 8108907e5f
3 changed files with 128 additions and 7 deletions

View file

@ -387,10 +387,62 @@ class FilteredLogModel (LogModelBase):
self.line_offsets[:] = (offset for row, offset in enum self.line_offsets[:] = (offset for row, offset in enum
if func (row)) if func (row))
def parent_line_index (self, line_index):
return line_index # FIXME
class Filter (object): class Filter (object):
pass pass
class SubRange (object):
def __init__ (self, l, start, end):
if start > end:
raise ValueError ("need start <= end")
self.l = l
self.start = start
self.end = end
def __getitem__ (self, i):
return self.l[i + self.start]
def __len__ (self):
return self.end - self.start
def __iter__ (self):
l = self.l
i = self.start
while i <= self.end:
yield l[i]
class RangeFilteredLogModel (FilteredLogModel):
def __init__ (self, lazy_log_model):
FilteredLogModel.__init__ (self, lazy_log_model)
self.line_index_range = None
def set_range (self, start_index, last_index):
self.line_index_range = (start_index, last_index,)
self.line_offsets = SubRange (self.parent_model.line_offsets,
start_index, last_index)
self.line_levels = SubRange (self.parent_model.line_levels,
start_index, last_index)
def parent_line_index (self, line_index):
start_index = self.line_index_range[0]
return line_index + start_index
class DebugLevelFilter (Filter): class DebugLevelFilter (Filter):
def __init__ (self, debug_level): def __init__ (self, debug_level):
@ -979,10 +1031,14 @@ class Window (object):
self.actions.reload_file.props.sensitive = False self.actions.reload_file.props.sensitive = False
group = gtk.ActionGroup ("RowActions") group = gtk.ActionGroup ("RowActions")
group.add_actions ([("edit-copy-line", gtk.STOCK_COPY, _("Copy line"), "<Ctrl>C"), group.add_actions ([("omit-before-line", None, _("Omit lines before this one")),
("omit-after-line", None, _("Omit lines after this one")),
("show-hidden-lines", None, _("Show omitted lines")),
("edit-copy-line", gtk.STOCK_COPY, _("Copy line"), "<Ctrl>C"),
("edit-copy-message", gtk.STOCK_COPY, _("Copy message")), ("edit-copy-message", gtk.STOCK_COPY, _("Copy message")),
("filter-out-higher-levels", None, _("Filter out higher debug levels"))]) ("filter-out-higher-levels", None, _("Filter out higher debug levels"))])
self.actions.add_group (group) self.actions.add_group (group)
self.actions.show_hidden_lines.props.sensitive = False
self.actions.add_group (self.column_manager.action_group) self.actions.add_group (self.column_manager.action_group)
@ -1034,6 +1090,7 @@ class Window (object):
for action_name in ("new-window", "open-file", "reload-file", for action_name in ("new-window", "open-file", "reload-file",
"close-window", "cancel-load", "close-window", "cancel-load",
"omit-before-line", "omit-after-line", "show-hidden-lines",
"edit-copy-line", "edit-copy-message", "edit-copy-line", "edit-copy-message",
"filter-out-higher-levels", "filter-out-higher-levels",
"show-about",): "show-about",):
@ -1137,6 +1194,51 @@ class Window (object):
self.close () self.close ()
def handle_omit_after_line_action_activate (self, action):
first_index = self.log_filter.parent_line_index (0)
try:
filtered_line_index = self.get_active_line_index ()
except ValueError:
return
last_index = self.log_filter.parent_line_index (filtered_line_index)
self.logger.info ("omitting lines after %i (abs %i), first line is abs %i",
filtered_line_index,
last_index,
first_index)
self.log_filter = RangeFilteredLogModel (self.log_model)
self.log_filter.set_range (first_index, last_index + 1)
self.log_view.props.model = self.log_filter
self.actions.show_hidden_lines.props.sensitive = True
def handle_omit_before_line_action_activate (self, action):
try:
filtered_line_index = self.get_active_line_index ()
except ValueError:
return
first_index = self.log_filter.parent_line_index (filtered_line_index)
last_index = self.log_filter.parent_line_index (len (self.log_filter) - 1)
self.logger.info ("omitting lines before %i (abs %i), last line is abs %i",
filtered_line_index,
first_index,
last_index)
self.log_filter = RangeFilteredLogModel (self.log_model)
self.log_filter.set_range (first_index, last_index)
self.log_view.props.model = self.log_filter
self.actions.show_hidden_lines.props.sensitive = True
def handle_show_hidden_lines_action_activate (self, action):
self.logger.info ("restoring model filter to show all lines")
self.log_filter = FilteredLogModel (self.log_model)
self.log_view.props.model = self.log_filter
self.actions.show_hidden_lines.props.sensitive = False
def handle_edit_copy_line_action_activate (self, action): def handle_edit_copy_line_action_activate (self, action):
line_index = self.get_active_line_index () line_index = self.get_active_line_index ()

View file

@ -647,8 +647,14 @@ class TimelineFeature (FeatureBase):
action.connect ("toggled", handler) action.connect ("toggled", handler)
action.props.active = self.state.shown action.props.active = self.state.shown
handler = self.handle_log_view_notify_model
self.notify_model_id = self.log_view.connect ("notify::model", handler)
def handle_detach_window (self, window): def handle_detach_window (self, window):
self.log_view.disconnect (self.notify_model_id)
self.log_view = None
window.ui_manager.remove_ui (self.merge_id) window.ui_manager.remove_ui (self.merge_id)
self.merge_id = None self.merge_id = None
@ -659,7 +665,22 @@ class TimelineFeature (FeatureBase):
def handle_attach_log_file (self, window, log_file): def handle_attach_log_file (self, window, log_file):
model = window.log_filter pass
def handle_detach_log_file (self, window, log_file):
self.timeline.clear ()
self.vtimeline.clear ()
def handle_log_view_notify_model (self, view, gparam):
model = view.props.model
if model is None:
self.timeline.clear ()
self.vtimeline.clear ()
return
self.timeline.update (model) self.timeline.update (model)
# Need to dispatch these idly with a low priority to avoid triggering a # Need to dispatch these idly with a low priority to avoid triggering a
@ -670,11 +691,6 @@ class TimelineFeature (FeatureBase):
return False return False
gobject.idle_add (idle_update, priority = gobject.PRIORITY_LOW) gobject.idle_add (idle_update, priority = gobject.PRIORITY_LOW)
def handle_detach_log_file (self, window, log_file):
self.timeline.clear ()
self.vtimeline.clear ()
def update_timeline_position (self): def update_timeline_position (self):
model = self.log_view.props.model model = self.log_view.props.model

View file

@ -24,6 +24,9 @@
</menu> </menu>
<placeholder name="ViewMenuAdditions"/> <placeholder name="ViewMenuAdditions"/>
<separator/> <separator/>
<menuitem name="ViewContextMenuOmitBefore" action="omit-before-line"/>
<menuitem name="ViewContextMenuOmitAfter" action="omit-after-line"/>
<menuitem name="ViewContextMenuShowHidden" action="show-hidden-lines"/>
<menuitem name="ViewContextMenuCopyMessage" action="edit-copy-message"/> <menuitem name="ViewContextMenuCopyMessage" action="edit-copy-message"/>
<menuitem name="ViewContextMenuCopyLine" action="edit-copy-line"/> <menuitem name="ViewContextMenuCopyLine" action="edit-copy-line"/>
<menuitem name="ViewContextMenuFilterLevel" action="filter-out-higher-levels"/> <menuitem name="ViewContextMenuFilterLevel" action="filter-out-higher-levels"/>