## common/helpers.py ## ## Gajim Team: ## - Yann Le Boulanger <asterix@lagaule.org> ## - Vincent Hanquez <tab@snarc.org> ## - Nikos Kouremenos <kourem@gmail.com> ## ## Copyright (C) 2003-2005 Gajim Team ## ## This program is free software; you can redistribute it and/or modify ## it under the terms of the GNU General Public License as published ## by the Free Software Foundation; version 2 only. ## ## This program is distributed in the hope that it will be useful, ## but WITHOUT ANY WARRANTY; without even the implied warranty of ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ## GNU General Public License for more details. ## import sre import os import gajim from common import i18n _ = i18n._ def convert_bytes(string): suffix = '' # IEC standard says KiB = 1024 bytes KB = 1000 bytes use_kib_mib = gajim.config.get('use_kib_mib') align = 1024. bytes = float(string) if bytes >= align: bytes = round(bytes/align, 1) if bytes >= align: bytes = round(bytes/align, 1) if bytes >= align: bytes = round(bytes/align, 1) if use_kib_mib: #GiB means gibibyte suffix = _('%s GiB') else: #GB means gigabyte suffix = _('%s GB') else: if use_kib_mib: #MiB means mibibyte suffix = _('%s MiB') else: #MB means megabyte suffix = _('%s MB') else: if use_kib_mib: #KiB means kibibyte suffix = _('%s KiB') else: #KB means kilo bytes suffix = _('%s KB') else: #B means bytes suffix = _('%s B') return suffix % str(bytes) def get_uf_show(show): '''returns a userfriendly string for dnd/xa/chat and makes all strings translatable''' if show == 'dnd': uf_show = _('Busy') elif show == 'xa': uf_show = _('Not Available') elif show == 'chat': uf_show = _('Free for Chat') elif show == 'online': uf_show = _('Available') elif show == 'connecting': uf_show = _('Connecting') elif show == 'away': uf_show = _('Away') elif show == 'offline': uf_show = _('Offline') elif show == 'invisible': uf_show = _('Invisible') elif show == 'not in the roster': uf_show = _('Not in the roster') elif show == 'requested': uf_show = _('Unknown') else: uf_show = _('Has errors') return unicode(uf_show) def get_uf_sub(sub): if sub == 'none': uf_sub = _('None') elif sub == 'to': uf_sub = _('To') elif sub == 'from': uf_sub = _('From') elif sub == 'both': uf_sub = _('Both') else: uf_sub = sub return unicode(uf_sub) def get_uf_ask(ask): if ask is None: uf_ask = _('None') elif ask == 'subscribe': uf_ask = _('Subscribe') else: uf_ask = ask return unicode(uf_ask) def get_sorted_keys(adict): keys = adict.keys() keys.sort() return keys def to_one_line(msg): msg = msg.replace('\\', '\\\\') msg = msg.replace('\n', '\\n') # s1 = 'test\ntest\\ntest' # s11 = s1.replace('\\', '\\\\') # s12 = s11.replace('\n', '\\n') # s12 # 'test\\ntest\\\\ntest' return msg def from_one_line(msg): # (?<!\\) is a lookbehind assertion which asks anything but '\' # to match the regexp that follows it # So here match '\\n' but not if you have a '\' before that re = sre.compile(r'(?<!\\)\\n') msg = re.sub('\n', msg) msg = msg.replace('\\\\', '\\') # s12 = 'test\\ntest\\\\ntest' # s13 = re.sub('\n', s12) # s14 s13.replace('\\\\', '\\') # s14 # 'test\ntest\\ntest' return msg def get_uf_chatstate(chatstate): '''removes chatstate jargon and returns user friendly messages''' if chatstate == 'active': return _('is paying attention to the conversation') elif chatstate == 'inactive': return _('is doing something else') elif chatstate == 'composing': return _('is composing a message...') elif chatstate == 'paused': #paused means he was compoing but has stopped for a while return _('paused composing a message') elif chatstate == 'gone': return _('has closed the chat window or tab') def is_in_path(name_of_command, return_abs_path = False): # if return_abs_path is True absolute path will be returned # for name_of_command # on failures False is returned is_in_dir = False found_in_which_dir = None path = os.getenv('PATH').split(':') for path_to_directory in path: try: contents = os.listdir(path_to_directory) except OSError: # user can have something in PATH that is not a dir pass else: is_in_dir = name_of_command in contents if is_in_dir: if return_abs_path: found_in_which_dir = path_to_directory break if found_in_which_dir: abs_path = os.path.join(path_to_directory, name_of_command) return abs_path else: return is_in_dir def launch_browser_mailer(kind, uri): #kind = 'url' or 'mail' if os.name == 'nt': try: os.startfile(uri) # if pywin32 is installed we open except: pass else: if kind == 'url' and not\ (uri.startswith('http://') or uri.startswith('https://')): uri = 'http://' + uri elif kind == 'mail' and not uri.startswith('mailto:'): uri = 'mailto:' + uri if gajim.config.get('openwith') == 'gnome-open': command = 'gnome-open' elif gajim.config.get('openwith') == 'kfmclient exec': command = 'kfmclient exec' elif gajim.config.get('openwith') == 'custom': if kind == 'url': command = gajim.config.get('custombrowser') if kind == 'mail': command = gajim.config.get('custommailapp') if command == '': # if no app is configured return # we add the uri in "" so we have good parsing from shell command = command + ' "' + uri + '" &' try: #FIXME: when we require python2.4+ use subprocess module os.system(command) except: pass def launch_file_manager(path_to_open): if os.name == 'nt': try: os.startfile(path_to_open) # if pywin32 is installed we open except: pass if gajim.config.get('openwith') == 'gnome-open': command = 'gnome-open' elif gajim.config.get('openwith') == 'kfmclient exec': command = 'kfmclient exec' elif gajim.config.get('openwith') == 'custom': command = gajim.config.get('custom_file_manager') if command == '': # if no app is configured return # we add the path in "" so we have good parsing from shell command = command + ' "' + uri + '" &' try: #FIXME: when we require python2.4+ use subprocess module os.system(command) except: pass def play_sound(event): if not gajim.config.get('sounds_on'): return path_to_soundfile = gajim.config.get_per('soundevents', event, 'path') if not os.path.exists(path_to_soundfile): return if os.name == 'nt': try: winsound.PlaySound(path_to_soundfile, winsound.SND_FILENAME|winsound.SND_ASYNC) except: pass elif os.name == 'posix': if gajim.config.get('soundplayer') == '': return player = gajim.config.get('soundplayer') # we add the path in "" so we have good parsing from shell command = player + ' "' + path_to_soundfile + '" &' #FIXME: when we require 2.4+ use subprocess module os.system(command)