Fix endless loop in various CellRenderers

context.get_background_color() first calls the CellRenderer to render
the cell before giving back the color.

When we call this inside a CellRenderer, this is an endless loop
This commit is contained in:
Philipp Hörist 2017-02-19 18:07:06 +01:00
parent 4a7e54347c
commit dd3a2f3abc
2 changed files with 7 additions and 50 deletions

View File

@ -75,18 +75,6 @@ class Column(IntEnum):
empty_pixbuf = GdkPixbuf.Pixbuf.new(GdkPixbuf.Colorspace.RGB, True, 8, 1, 1) empty_pixbuf = GdkPixbuf.Pixbuf.new(GdkPixbuf.Colorspace.RGB, True, 8, 1, 1)
empty_pixbuf.fill(0xffffff00) empty_pixbuf.fill(0xffffff00)
def set_renderer_color(treeview, renderer, set_background=True):
"""
Set style for group row, using PRELIGHT system color
"""
context = treeview.get_style_context()
if set_background:
bgcolor = context.get_background_color(Gtk.StateFlags.PRELIGHT)
renderer.set_property('cell-background-rgba', bgcolor)
else:
fgcolor = context.get_color(Gtk.StateFlags.PRELIGHT)
renderer.set_property('foreground-rgba', fgcolor)
def tree_cell_data_func(column, renderer, model, iter_, tv=None): def tree_cell_data_func(column, renderer, model, iter_, tv=None):
# cell data func is global, because we don't want it to keep # cell data func is global, because we don't want it to keep
# reference to GroupchatControl instance (self) # reference to GroupchatControl instance (self)
@ -123,17 +111,11 @@ def tree_cell_data_func(column, renderer, model, iter_, tv=None):
gtkgui_helpers.get_theme_font_for_option(theme, 'contactfont')) gtkgui_helpers.get_theme_font_for_option(theme, 'contactfont'))
else: # it is root (eg. group) else: # it is root (eg. group)
bgcolor = gajim.config.get_per('themes', theme, 'groupbgcolor') bgcolor = gajim.config.get_per('themes', theme, 'groupbgcolor')
if bgcolor: renderer.set_property('cell-background', bgcolor or None)
renderer.set_property('cell-background', bgcolor)
else:
set_renderer_color(tv, renderer)
if isinstance(renderer, Gtk.CellRendererText): if isinstance(renderer, Gtk.CellRendererText):
# foreground property is only with CellRendererText # foreground property is only with CellRendererText
color = gajim.config.get_per('themes', theme, 'grouptextcolor') color = gajim.config.get_per('themes', theme, 'grouptextcolor')
if color: renderer.set_property('foreground', color or None)
renderer.set_property('foreground', color)
else:
set_renderer_color(tv, renderer, False)
renderer.set_property('font', renderer.set_property('font',
gtkgui_helpers.get_theme_font_for_option(theme, 'groupfont')) gtkgui_helpers.get_theme_font_for_option(theme, 'groupfont'))

View File

@ -4814,19 +4814,6 @@ class RosterWindow:
if ctrl: if ctrl:
ctrl.show_avatar() ctrl.show_avatar()
def set_renderer_color(self, renderer, style, set_background=True):
"""
Set style for treeview cell, using PRELIGHT system color
"""
if set_background:
context = self.tree.get_style_context()
bgcolor = context.get_background_color(style)
renderer.set_property('cell-background-rgba', bgcolor)
else:
context = self.tree.get_style_context()
fgcolor = context.get_color(style)
renderer.set_property('foreground-rgba', fgcolor)
def _iconCellDataFunc(self, column, renderer, model, titer, data=None): def _iconCellDataFunc(self, column, renderer, model, titer, data=None):
""" """
When a row is added, set properties for icon renderer When a row is added, set properties for icon renderer
@ -4871,10 +4858,7 @@ class RosterWindow:
theme = gajim.config.get('roster_theme') theme = gajim.config.get('roster_theme')
if type_ == 'account': if type_ == 'account':
color = gajim.config.get_per('themes', theme, 'accounttextcolor') color = gajim.config.get_per('themes', theme, 'accounttextcolor')
if color: renderer.set_property('foreground', color or None)
renderer.set_property('foreground', color)
else:
self.set_renderer_color(renderer, Gtk.StateFlags.ACTIVE, False)
renderer.set_property('font', renderer.set_property('font',
gtkgui_helpers.get_theme_font_for_option(theme, 'accountfont')) gtkgui_helpers.get_theme_font_for_option(theme, 'accountfont'))
renderer.set_property('xpad', 0) renderer.set_property('xpad', 0)
@ -4882,10 +4866,7 @@ class RosterWindow:
self._set_account_row_background_color(renderer) self._set_account_row_background_color(renderer)
elif type_ == 'group': elif type_ == 'group':
color = gajim.config.get_per('themes', theme, 'grouptextcolor') color = gajim.config.get_per('themes', theme, 'grouptextcolor')
if color: renderer.set_property('foreground', color or None)
renderer.set_property('foreground', color)
else:
self.set_renderer_color(renderer, Gtk.StateFlags.PRELIGHT, False)
renderer.set_property('font', renderer.set_property('font',
gtkgui_helpers.get_theme_font_for_option(theme, 'groupfont')) gtkgui_helpers.get_theme_font_for_option(theme, 'groupfont'))
parent_iter = model.iter_parent(titer) parent_iter = model.iter_parent(titer)
@ -5012,10 +4993,7 @@ class RosterWindow:
def _set_account_row_background_color(self, renderer): def _set_account_row_background_color(self, renderer):
theme = gajim.config.get('roster_theme') theme = gajim.config.get('roster_theme')
color = gajim.config.get_per('themes', theme, 'accountbgcolor') color = gajim.config.get_per('themes', theme, 'accountbgcolor')
if color: renderer.set_property('cell-background', color or None)
renderer.set_property('cell-background', color)
else:
self.set_renderer_color(renderer, Gtk.StateFlags.ACTIVE)
def _set_contact_row_background_color(self, renderer, jid, account): def _set_contact_row_background_color(self, renderer, jid, account):
theme = gajim.config.get('roster_theme') theme = gajim.config.get('roster_theme')
@ -5027,15 +5005,12 @@ class RosterWindow:
'just_disconnected_bg_color')) 'just_disconnected_bg_color'))
else: else:
color = gajim.config.get_per('themes', theme, 'contactbgcolor') color = gajim.config.get_per('themes', theme, 'contactbgcolor')
renderer.set_property('cell-background', color if color else None) renderer.set_property('cell-background', color or None)
def _set_group_row_background_color(self, renderer): def _set_group_row_background_color(self, renderer):
theme = gajim.config.get('roster_theme') theme = gajim.config.get('roster_theme')
color = gajim.config.get_per('themes', theme, 'groupbgcolor') color = gajim.config.get_per('themes', theme, 'groupbgcolor')
if color: renderer.set_property('cell-background', color or None)
renderer.set_property('cell-background', color)
else:
self.set_renderer_color(renderer, Gtk.StateFlags.PRELIGHT)
################################################################################ ################################################################################
### Everything about building menus ### Everything about building menus