Stop loading all transport iconsets at launch. Load them on the fly, if and when needed. Speedup gajim start and

use less mem :)
This commit is contained in:
Jean-Marie Traissard 2008-03-19 00:25:28 +00:00
parent 80aeea1bd0
commit 7dca69467e
1 changed files with 48 additions and 52 deletions

View File

@ -602,10 +602,13 @@ class RosterWindow:
transport: transport iconset doesn't contain all icons, so we fall back transport: transport iconset doesn't contain all icons, so we fall back
to jabber one''' to jabber one'''
transport = gajim.get_transport_name_from_jid(jid) transport = gajim.get_transport_name_from_jid(jid)
if transport and self.transports_state_images.has_key(size) and \ if transport and self.transports_state_images.has_key(size):
self.transports_state_images[size].has_key(transport) and icon_name in \ if not self.transports_state_images[size].has_key(transport):
self.transports_state_images[size][transport]: # we don't have iconset for this transport loaded yet. Let's do it
return self.transports_state_images[size][transport] self.make_transport_state_images(transport)
if self.transports_state_images[size].has_key(transport) and \
icon_name in self.transports_state_images[size][transport]:
return self.transports_state_images[size][transport]
return self.jabber_state_images[size] return self.jabber_state_images[size]
def draw_contact(self, jid, account, selected = False, focus = False): def draw_contact(self, jid, account, selected = False, focus = False):
@ -4507,6 +4510,29 @@ class RosterWindow:
icon_list = self._load_icon_list([icon_name], path) icon_list = self._load_icon_list([icon_name], path)
return icon_list[icon_name] return icon_list[icon_name]
def load_icons_meta(self):
'''load and return - AND + small icons to put on top left of an icon
for meta contacts.'''
iconset = gajim.config.get('iconset')
path = os.path.join(helpers.get_iconset_path(iconset), '16x16')
# try to find opened_meta.png file, else opened.png else nopixbuf merge
path_opened = os.path.join(path, 'opened_meta.png')
if not os.path.isfile(path_opened):
path_opened = os.path.join(path, 'opened.png')
if os.path.isfile(path_opened):
pixo = gtk.gdk.pixbuf_new_from_file(path_opened)
else:
pixo = None
# Same thing for closed
path_closed = os.path.join(path, 'opened_meta.png')
if not os.path.isfile(path_closed):
path_closed = os.path.join(path, 'closed.png')
if os.path.isfile(path_closed):
pixc = gtk.gdk.pixbuf_new_from_file(path_closed)
else:
pixc = None
return pixo, pixc
def _load_icon_list(self, icons_list, path, pixbuf2 = None): def _load_icon_list(self, icons_list, path, pixbuf2 = None):
'''load icons in icons_list from the given path, '''load icons in icons_list from the given path,
and add pixbuf2 on top left of each static images''' and add pixbuf2 on top left of each static images'''
@ -4549,42 +4575,27 @@ class RosterWindow:
path = os.path.join(helpers.get_iconset_path(iconset), '16x16') path = os.path.join(helpers.get_iconset_path(iconset), '16x16')
self.jabber_state_images['16'] = self.load_iconset(path) self.jabber_state_images['16'] = self.load_iconset(path)
# try to find opened_meta.png file, else opened.png else nopixbuf merge
path_opened = os.path.join(path, 'opened_meta.png') pixo, pixc = self.load_icons_meta()
if not os.path.isfile(path_opened):
path_opened = os.path.join(path, 'opened.png')
if os.path.isfile(path_opened):
pixo = gtk.gdk.pixbuf_new_from_file(path_opened)
else:
pixo = None
self.jabber_state_images['opened'] = self.load_iconset(path, pixo) self.jabber_state_images['opened'] = self.load_iconset(path, pixo)
# Same thing for closed
path_closed = os.path.join(path, 'opened_meta.png')
if not os.path.isfile(path_closed):
path_closed = os.path.join(path, 'closed.png')
if os.path.isfile(path_closed):
pixc = gtk.gdk.pixbuf_new_from_file(path_closed)
else:
pixc = None
self.jabber_state_images['closed'] = self.load_iconset(path, pixc) self.jabber_state_images['closed'] = self.load_iconset(path, pixc)
def make_transport_state_images(self, transport):
'''initialise opened and closed 'transport' iconset dict'''
if gajim.config.get('use_transports_iconsets'): if gajim.config.get('use_transports_iconsets'):
# update opened and closed transport iconsets folder = os.path.join(helpers.get_transport_path(transport),
# standard transport iconsets are loaded one time in init() '16x16')
t_path = os.path.join(gajim.DATA_DIR, 'iconsets', 'transports') pixo, pixc = self.load_icons_meta()
folders = os.listdir(t_path) self.transports_state_images['opened'][transport] = \
if os.path.isdir(os.path.join(gajim.MY_ICONSETS_PATH, 'transports')): self.load_iconset(folder, pixo, transport = True)
t_path = os.path.join(gajim.MY_ICONSETS_PATH, 'transports') self.transports_state_images['closed'][transport] = \
folders += os.listdir(t_path) self.load_iconset(folder, pixc, transport = True)
for transport in folders: folder = os.path.join(helpers.get_transport_path(transport), '32x32')
if transport == '.svn': self.transports_state_images['32'][transport] = self.load_iconset(
continue folder, transport = True)
folder = os.path.join(helpers.get_transport_path(transport), folder = os.path.join(helpers.get_transport_path(transport), '16x16')
'16x16') self.transports_state_images['16'][transport] = self.load_iconset(
self.transports_state_images['opened'][transport] = \ folder, transport = True)
self.load_iconset(folder, pixo, transport = True)
self.transports_state_images['closed'][transport] = \
self.load_iconset(folder, pixc, transport = True)
def reload_jabber_state_images(self): def reload_jabber_state_images(self):
self.make_jabber_state_images() self.make_jabber_state_images()
@ -5405,21 +5416,6 @@ class RosterWindow:
self.quit_on_next_offline = -1 self.quit_on_next_offline = -1
self.make_jabber_state_images() self.make_jabber_state_images()
path = os.path.join(gajim.DATA_DIR, 'iconsets', 'transports')
folders = os.listdir(path)
if os.path.isdir(os.path.join(gajim.MY_ICONSETS_PATH, 'transports')):
path = os.path.join(gajim.MY_ICONSETS_PATH, 'transports')
folders += os.listdir(path)
for transport in folders:
if transport == '.svn':
continue
folder = os.path.join(helpers.get_transport_path(transport), '32x32')
self.transports_state_images['32'][transport] = self.load_iconset(
folder, transport = True)
folder = os.path.join(helpers.get_transport_path(transport), '16x16')
self.transports_state_images['16'][transport] = self.load_iconset(
folder, transport = True)
# uf_show, img, show, sensitive # uf_show, img, show, sensitive
liststore = gtk.ListStore(str, gtk.Image, str, bool) liststore = gtk.ListStore(str, gtk.Image, str, bool)
self.status_combobox = self.xml.get_widget('status_combobox') self.status_combobox = self.xml.get_widget('status_combobox')