mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 01:45:33 +00:00
Add ranged line omission feature
This commit is contained in:
parent
cb6d082f19
commit
8108907e5f
3 changed files with 128 additions and 7 deletions
|
@ -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 ()
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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"/>
|
||||||
|
|
Loading…
Reference in a new issue