Refinements on statusbar update; only updated when really necessary; fixed bug in updating when db is closed
svn: r14141
This commit is contained in:
parent
e7c5d7a207
commit
81bb97e2df
@ -265,7 +265,8 @@ class Gramplet(object):
|
||||
"""
|
||||
import gobject
|
||||
if ((not self.active or
|
||||
self.gui.state in ["closed", "minimized"]) and
|
||||
self.gui.state in ["closed", "minimized"] or
|
||||
not self.dbstate.open) and
|
||||
not self.gui.force_update):
|
||||
self.dirty = True
|
||||
#print " %s is not active" % self.gui.title
|
||||
@ -287,16 +288,22 @@ class Gramplet(object):
|
||||
"""
|
||||
if not isinstance(self._generator, types.GeneratorType):
|
||||
self._idle_id = 0
|
||||
self.uistate.push_message(self.dbstate,
|
||||
_("Gramplet %s updated") % self.gui.title)
|
||||
return False
|
||||
try:
|
||||
retval = self._generator.next()
|
||||
if not retval:
|
||||
self._idle_id = 0
|
||||
if self._pause:
|
||||
self.uistate.push_message(self.dbstate,
|
||||
_("Gramplet %s updated") % self.gui.title)
|
||||
return False
|
||||
return retval
|
||||
except StopIteration:
|
||||
self._idle_id = 0
|
||||
self.uistate.push_message(self.dbstate,
|
||||
_("Gramplet %s updated") % self.gui.title)
|
||||
return False
|
||||
except Exception, e:
|
||||
import traceback
|
||||
@ -304,6 +311,8 @@ class Gramplet(object):
|
||||
traceback.print_exc()
|
||||
print "Continuing after gramplet error..."
|
||||
self._idle_id = 0
|
||||
self.uistate.push_message(self.dbstate,
|
||||
_("Gramplet %s caused an error") % self.gui.title)
|
||||
return False
|
||||
|
||||
def pause(self, *args):
|
||||
|
@ -422,6 +422,7 @@ class GuiGramplet(object):
|
||||
padding,
|
||||
pack)
|
||||
if oldstate is "minimized" and self.pui:
|
||||
if self.pui.dirty:
|
||||
self.pui.update()
|
||||
|
||||
def change_state(self, obj):
|
||||
|
Loading…
x
Reference in New Issue
Block a user