remove call to unicode()

This commit is contained in:
Yann Leboulanger 2013-01-01 21:06:16 +01:00
parent 414e349345
commit 069bddbbcb
47 changed files with 189 additions and 256 deletions

View File

@ -281,8 +281,6 @@ class CommandWindow:
# close old stage # close old stage
self.stage_finish() self.stage_finish()
assert isinstance(self.commandnode, unicode)
self.form_status = None self.form_status = None
self.stages_notebook.set_current_page( self.stages_notebook.set_current_page(
@ -608,7 +606,6 @@ class CommandWindow:
Send the command with data form. Wait for reply Send the command with data form. Wait for reply
""" """
# create the stanza # create the stanza
assert isinstance(self.commandnode, unicode)
assert action in ('execute', 'prev', 'next', 'complete') assert action in ('execute', 'prev', 'next', 'complete')
stanza = nbxmpp.Iq(typ='set', to=self.jid) stanza = nbxmpp.Iq(typ='set', to=self.jid)

View File

@ -2505,7 +2505,7 @@ class ChatControl(ChatControlBase):
if num_unread == 1 and not gajim.config.get('show_unread_tab_icon'): if num_unread == 1 and not gajim.config.get('show_unread_tab_icon'):
unread = '*' unread = '*'
elif num_unread > 1: elif num_unread > 1:
unread = '[' + unicode(num_unread) + ']' unread = '[' + str(num_unread) + ']'
# Draw tab label using chatstate # Draw tab label using chatstate
theme = gajim.config.get('roster_theme') theme = gajim.config.get('roster_theme')

View File

@ -32,7 +32,7 @@ over the process.
""" """
from types import NoneType from types import NoneType
from tools import remove from .tools import remove
COMMANDS = {} COMMANDS = {}
CONTAINERS = {} CONTAINERS = {}

View File

@ -23,10 +23,10 @@ import re
from types import FunctionType from types import FunctionType
from inspect import getargspec, getdoc from inspect import getargspec, getdoc
from dispatcher import Host, Container from .dispatcher import Host, Container
from dispatcher import get_command, list_commands from .dispatcher import get_command, list_commands
from mapping import parse_arguments, adapt_arguments from mmapping import parse_arguments, adapt_arguments
from errors import DefinitionError, CommandError, NoCommandError from .errors import DefinitionError, CommandError, NoCommandError
class CommandHost(object): class CommandHost(object):
""" """

View File

@ -35,7 +35,7 @@ detected.
""" """
from ..framework import CommandContainer, command, doc from ..framework import CommandContainer, command, doc
from hosts import * from .hosts import *
class CustomCommonCommands(CommandContainer): class CustomCommonCommands(CommandContainer):
""" """

View File

@ -38,7 +38,7 @@ from os.path import expanduser
from glib import timeout_add from glib import timeout_add
from ..framework import CommandContainer, command, doc from ..framework import CommandContainer, command, doc
from hosts import * from .hosts import *
class Execute(CommandContainer): class Execute(CommandContainer):
AUTOMATIC = True AUTOMATIC = True

View File

@ -30,8 +30,8 @@ from ..errors import CommandError
from ..framework import CommandContainer, command, doc from ..framework import CommandContainer, command, doc
from ..mapping import generate_usage from ..mapping import generate_usage
from hosts import * from .hosts import *
import execute from . import execute
# This holds constants fron the logger, which we'll be using in some of our # This holds constants fron the logger, which we'll be using in some of our
# commands. # commands.

View File

@ -26,7 +26,7 @@ import re
from types import BooleanType, UnicodeType from types import BooleanType, UnicodeType
from operator import itemgetter from operator import itemgetter
from errors import DefinitionError, CommandError from .errors import DefinitionError, CommandError
# Quite complex piece of regular expression logic to parse options and # Quite complex piece of regular expression logic to parse options and
# arguments. Might need some tweaking along the way. # arguments. Might need some tweaking along the way.
@ -269,12 +269,6 @@ def adapt_arguments(command, arguments, args, opts):
if not isinstance(value, BooleanType): if not isinstance(value, BooleanType):
raise CommandError("%s: Switch can not take an argument" % key, command) raise CommandError("%s: Switch can not take an argument" % key, command)
# We need to encode every keyword argument to a simple string, not
# the unicode one, because ** expansion does not support it.
for index, (key, value) in enumerate(opts):
if isinstance(key, UnicodeType):
opts[index] = (key.encode(KEY_ENCODING), value)
# Inject the source arguments as a string as a first argument, if # Inject the source arguments as a string as a first argument, if
# command has enabled the corresponding option. # command has enabled the corresponding option.
if command.source: if command.source:

View File

@ -29,7 +29,7 @@ import sys
import stat import stat
from common import gajim from common import gajim
import logger from common import logger
from common import jingle_xtls from common import jingle_xtls
# DO NOT MOVE ABOVE OF import gajim # DO NOT MOVE ABOVE OF import gajim

View File

@ -23,9 +23,9 @@
## ##
import nbxmpp import nbxmpp
import helpers from common import helpers
import dataforms from common import dataforms
import gajim from common import gajim
import logging import logging
log = logging.getLogger('gajim.c.commands') log = logging.getLogger('gajim.c.commands')

View File

@ -61,7 +61,7 @@ def fse(s):
""" """
Convert from filesystem encoding if not already Unicode Convert from filesystem encoding if not already Unicode
""" """
return unicode(s, sys.getfilesystemencoding()) return s
def windowsify(s): def windowsify(s):
if os.name == 'nt': if os.name == 'nt':

View File

@ -616,7 +616,7 @@ class CommonConnection:
if realm == '': if realm == '':
if event == nbxmpp.transports_nb.DATA_RECEIVED: if event == nbxmpp.transports_nb.DATA_RECEIVED:
gajim.nec.push_incoming_event(StanzaReceivedEvent(None, gajim.nec.push_incoming_event(StanzaReceivedEvent(None,
conn=self, stanza_str=unicode(data, errors='ignore'))) conn=self, stanza_str=data))
elif event == nbxmpp.transports_nb.DATA_SENT: elif event == nbxmpp.transports_nb.DATA_SENT:
gajim.nec.push_incoming_event(StanzaSentEvent(None, conn=self, gajim.nec.push_incoming_event(StanzaSentEvent(None, conn=self,
stanza_str=data)) stanza_str=data))
@ -1446,7 +1446,7 @@ class Connection(CommonConnection, ConnectionHandlers):
self.connection.send(' ') self.connection.send(' ')
def _on_xmpp_ping_answer(self, iq_obj): def _on_xmpp_ping_answer(self, iq_obj):
id_ = unicode(iq_obj.getAttr('id')) id_ = iq_obj.getAttr('id')
assert id_ == self.awaiting_xmpp_ping_id assert id_ == self.awaiting_xmpp_ping_id
self.awaiting_xmpp_ping_id = None self.awaiting_xmpp_ping_id = None
@ -1607,7 +1607,7 @@ class Connection(CommonConnection, ConnectionHandlers):
self.activate_privacy_rule('invisible') self.activate_privacy_rule('invisible')
self.connected = gajim.SHOW_LIST.index('invisible') self.connected = gajim.SHOW_LIST.index('invisible')
self.status = msg self.status = msg
priority = unicode(gajim.get_priority(self.name, 'invisible')) priority = gajim.get_priority(self.name, 'invisible')
p = nbxmpp.Presence(priority=priority) p = nbxmpp.Presence(priority=priority)
p = self.add_sha(p, True) p = self.add_sha(p, True)
if msg: if msg:
@ -1781,7 +1781,7 @@ class Connection(CommonConnection, ConnectionHandlers):
p.setStatus(msg) p.setStatus(msg)
else: else:
signed = self.get_signed_presence(msg) signed = self.get_signed_presence(msg)
priority = unicode(gajim.get_priority(self.name, sshow)) priority = gajim.get_priority(self.name, sshow)
p = nbxmpp.Presence(typ=None, priority=priority, show=sshow, to=jid) p = nbxmpp.Presence(typ=None, priority=priority, show=sshow, to=jid)
p = self.add_sha(p) p = self.add_sha(p)
if msg: if msg:
@ -1805,7 +1805,7 @@ class Connection(CommonConnection, ConnectionHandlers):
def _update_status(self, show, msg): def _update_status(self, show, msg):
xmpp_show = helpers.get_xmpp_show(show) xmpp_show = helpers.get_xmpp_show(show)
priority = unicode(gajim.get_priority(self.name, xmpp_show)) priority = gajim.get_priority(self.name, xmpp_show)
p = nbxmpp.Presence(typ=None, priority=priority, show=xmpp_show) p = nbxmpp.Presence(typ=None, priority=priority, show=xmpp_show)
p = self.add_sha(p) p = self.add_sha(p)
if msg: if msg:

View File

@ -39,7 +39,7 @@ from time import (altzone, daylight, gmtime, localtime, mktime, strftime,
from calendar import timegm from calendar import timegm
import nbxmpp import nbxmpp
import common.caps_cache as capscache from common import caps_cache as capscache
from common import helpers from common import helpers
from common import gajim from common import gajim
@ -181,8 +181,8 @@ class ConnectionDisco:
if not self.connection or self.connected < 2: if not self.connection or self.connected < 2:
return return
frm = helpers.get_full_jid_from_iq(iq_obj) frm = helpers.get_full_jid_from_iq(iq_obj)
to = unicode(iq_obj.getAttr('to')) to = iq_obj.getAttr('to')
id_ = unicode(iq_obj.getAttr('id')) id_ = iq_obj.getAttr('id')
iq = nbxmpp.Iq(to=frm, typ='result', queryNS=nbxmpp.NS_DISCO, frm=to) iq = nbxmpp.Iq(to=frm, typ='result', queryNS=nbxmpp.NS_DISCO, frm=to)
iq.setAttr('id', id_) iq.setAttr('id', id_)
query = iq.setTag('query') query = iq.setTag('query')
@ -235,7 +235,7 @@ class ConnectionDisco:
if self.commandInfoQuery(con, iq_obj): if self.commandInfoQuery(con, iq_obj):
raise nbxmpp.NodeProcessed raise nbxmpp.NodeProcessed
id_ = unicode(iq_obj.getAttr('id')) id_ = iq_obj.getAttr('id')
if id_[:6] == 'Gajim_': if id_[:6] == 'Gajim_':
# We get this request from echo.server # We get this request from echo.server
raise nbxmpp.NodeProcessed raise nbxmpp.NodeProcessed

View File

@ -39,7 +39,7 @@ from nbxmpp.protocol import NS_CHATSTATES
from common.jingle_transport import JingleTransportSocks5 from common.jingle_transport import JingleTransportSocks5
from common.file_props import FilesProp from common.file_props import FilesProp
import gtkgui_helpers from . import gtkgui_helpers
import logging import logging
log = logging.getLogger('gajim.c.connection_handlers_events') log = logging.getLogger('gajim.c.connection_handlers_events')
@ -1169,7 +1169,6 @@ class ZeroconfMessageReceivedEvent(MessageReceivedEvent):
self.fjid = key self.fjid = key
break break
self.fjid = unicode(self.fjid)
self.jid, self.resource = gajim.get_room_and_nick_from_fjid(self.fjid) self.jid, self.resource = gajim.get_room_and_nick_from_fjid(self.fjid)
def generate(self): def generate(self):
@ -1986,7 +1985,7 @@ class FileRequestReceivedEvent(nec.NetworkIncomingEvent, HelperEvent):
self.FT_content.session.ourjid) self.FT_content.session.ourjid)
self.FT_content.transport.set_connection( self.FT_content.transport.set_connection(
self.FT_content.session.connection) self.FT_content.session.connection)
sid = unicode(self.stanza.getTag('jingle').getAttr('sid')) sid = self.stanza.getTag('jingle').getAttr('sid')
self.file_props = FilesProp.getNewFileProp(self.conn.name, sid) self.file_props = FilesProp.getNewFileProp(self.conn.name, sid)
self.file_props.transport_sid = self.FT_content.transport.sid self.file_props.transport_sid = self.FT_content.transport.sid
self.FT_content.file_props = self.file_props self.FT_content.file_props = self.file_props
@ -2033,8 +2032,7 @@ class FileRequestReceivedEvent(nec.NetworkIncomingEvent, HelperEvent):
else: else:
si = self.stanza.getTag('si') si = self.stanza.getTag('si')
self.file_props = FilesProp.getNewFileProp(self.conn.name, self.file_props = FilesProp.getNewFileProp(self.conn.name,
unicode(si.getAttr('id')) si.getAttr('id'))
)
profile = si.getAttr('profile') profile = si.getAttr('profile')
if profile != nbxmpp.NS_FILE: if profile != nbxmpp.NS_FILE:
self.conn.send_file_rejection(self.file_props, code='400', self.conn.send_file_rejection(self.file_props, code='400',

View File

@ -27,7 +27,7 @@ information how to use them, read documentation
""" """
import nbxmpp import nbxmpp
import helpers from common import helpers
# exceptions used in this module # exceptions used in this module
# base class # base class
@ -345,7 +345,7 @@ class StringField(DataField):
@nested_property @nested_property
def value(): def value():
""" """
Value of field. May be any unicode string Value of field. May be any string
""" """
def fget(self): def fget(self):
return self.getTagData('value') or '' return self.getTagData('value') or ''

View File

@ -31,10 +31,10 @@ import sys
import logging import logging
import locale import locale
import config from common import config
import nbxmpp import nbxmpp
import defs from common import defs
import common.ged from common import ged
interface = None # The actual interface (the gtk one for the moment) interface = None # The actual interface (the gtk one for the moment)
thread_interface = None # Interface to run a thread and then a callback thread_interface = None # Interface to run a thread and then a callback
@ -280,13 +280,8 @@ def get_jid_without_resource(jid):
return jid.split('/')[0] return jid.split('/')[0]
def construct_fjid(room_jid, nick): def construct_fjid(room_jid, nick):
"""
Nick is in UTF-8 (taken from treeview); room_jid is in unicode
"""
# fake jid is the jid for a contact in a room # fake jid is the jid for a contact in a room
# gaim@conference.jabber.org/nick # gaim@conference.jabber.org/nick
if isinstance(nick, str):
nick = unicode(nick, 'utf-8')
return room_jid + '/' + nick return room_jid + '/' + nick
def get_resource_from_jid(jid): def get_resource_from_jid(jid):

View File

@ -26,7 +26,7 @@ from gajim import HAVE_GPG
import os import os
if HAVE_GPG: if HAVE_GPG:
import gnupg from common import gnupg
class GnuPG(gnupg.GPG): class GnuPG(gnupg.GPG):
def __init__(self, use_agent=False): def __init__(self, use_agent=False):

View File

@ -42,7 +42,7 @@ import select
import base64 import base64
import hashlib import hashlib
import shlex import shlex
import caps_cache from common import caps_cache
import socket import socket
import time import time
@ -159,7 +159,7 @@ def prep(user, server, resource):
raise InvalidFormat, _('Username must be between 1 and 1023 chars') raise InvalidFormat, _('Username must be between 1 and 1023 chars')
try: try:
from nbxmpp.stringprepare import nodeprep from nbxmpp.stringprepare import nodeprep
user = nodeprep.prepare(unicode(user)).encode('utf-8') user = nodeprep.prepare(user)
except UnicodeError: except UnicodeError:
raise InvalidFormat, _('Invalid character in username.') raise InvalidFormat, _('Invalid character in username.')
else: else:
@ -170,7 +170,7 @@ def prep(user, server, resource):
raise InvalidFormat, _('Server must be between 1 and 1023 chars') raise InvalidFormat, _('Server must be between 1 and 1023 chars')
try: try:
from nbxmpp.stringprepare import nameprep from nbxmpp.stringprepare import nameprep
server = nameprep.prepare(unicode(server)).encode('utf-8') server = nameprep.prepare(server)
except UnicodeError: except UnicodeError:
raise InvalidFormat, _('Invalid character in hostname.') raise InvalidFormat, _('Invalid character in hostname.')
else: else:
@ -181,7 +181,7 @@ def prep(user, server, resource):
raise InvalidFormat, _('Resource must be between 1 and 1023 chars') raise InvalidFormat, _('Resource must be between 1 and 1023 chars')
try: try:
from nbxmpp.stringprepare import resourceprep from nbxmpp.stringprepare import resourceprep
resource = resourceprep.prepare(unicode(resource)).encode('utf-8') resource = resourceprep.prepare(resource)
except UnicodeError: except UnicodeError:
raise InvalidFormat, _('Invalid character in resource.') raise InvalidFormat, _('Invalid character in resource.')
else: else:
@ -448,43 +448,43 @@ def get_output_of_command(command):
return output return output
def decode_string(string): #def decode_string(string):
""" #"""
Try to decode (to make it Unicode instance) given string #Try to decode (to make it Unicode instance) given string
""" #"""
if isinstance(string, unicode): #if isinstance(string, unicode):
return string #return string
# by the time we go to iso15 it better be the one else we show bad characters ## by the time we go to iso15 it better be the one else we show bad characters
encodings = (locale.getpreferredencoding(), 'utf-8', 'iso-8859-15') #encodings = (locale.getpreferredencoding(), 'utf-8', 'iso-8859-15')
for encoding in encodings: #for encoding in encodings:
try: #try:
string = string.decode(encoding) #string = string.decode(encoding)
except UnicodeError: #except UnicodeError:
continue #continue
break #break
return string #return string
def ensure_utf8_string(string): #def ensure_utf8_string(string):
""" #"""
Make sure string is in UTF-8 #Make sure string is in UTF-8
""" #"""
try: #try:
string = decode_string(string).encode('utf-8') #string = decode_string(string).encode('utf-8')
except Exception: #except Exception:
pass #pass
return string #return string
def wrapped_ensure_utf8_string(fn): #def wrapped_ensure_utf8_string(fn):
def wrapped(n): #def wrapped(n):
return ensure_utf8_string(n) #return ensure_utf8_string(n)
return wrapped #return wrapped
@wrapped_ensure_utf8_string #@wrapped_ensure_utf8_string
def escape_text(text): #def escape_text(text):
return GObject.markup_escape_text(text) #return GObject.markup_escape_text(text)
GObject.markup_escape_text = escape_text #GObject.markup_escape_text = escape_text
def get_windows_reg_env(varname, default=''): def get_windows_reg_env(varname, default=''):
""" """
@ -645,13 +645,13 @@ def convert_bytes(string):
# but do we use the standard? # but do we use the standard?
use_kib_mib = gajim.config.get('use_kib_mib') use_kib_mib = gajim.config.get('use_kib_mib')
align = 1024. align = 1024.
bytes = float(string) bytes_ = float(string)
if bytes >= align: if bytes_ >= align:
bytes = round(bytes/align, 1) bytes_ = round(bytes_/align, 1)
if bytes >= align: if bytes_ >= align:
bytes = round(bytes/align, 1) bytes_ = round(bytes_/align, 1)
if bytes >= align: if bytes_ >= align:
bytes = round(bytes/align, 1) bytes_ = round(bytes_/align, 1)
if use_kib_mib: if use_kib_mib:
#GiB means gibibyte #GiB means gibibyte
suffix = _('%s GiB') suffix = _('%s GiB')
@ -675,7 +675,7 @@ def convert_bytes(string):
else: else:
#B means bytes #B means bytes
suffix = _('%s B') suffix = _('%s B')
return suffix % unicode(bytes) return suffix % str(bytes_)
def get_contact_dict_for_account(account): def get_contact_dict_for_account(account):
""" """
@ -901,13 +901,13 @@ def get_icon_name_to_show(contact, account = None):
def get_full_jid_from_iq(iq_obj): def get_full_jid_from_iq(iq_obj):
""" """
Return the full jid (with resource) from an iq as unicode Return the full jid (with resource) from an iq
""" """
return parse_jid(str(iq_obj.getFrom())) return parse_jid(iq_obj.getFrom())
def get_jid_from_iq(iq_obj): def get_jid_from_iq(iq_obj):
""" """
Return the jid (without resource) from an iq as unicode Return the jid (without resource) from an iq
""" """
jid = get_full_jid_from_iq(iq_obj) jid = get_full_jid_from_iq(iq_obj)
return gajim.get_jid_without_resource(jid) return gajim.get_jid_without_resource(jid)

View File

@ -24,7 +24,7 @@
import locale import locale
import gettext import gettext
import os import os
import defs from common import defs
import unicodedata import unicodedata
def paragraph_direction_mark(text): def paragraph_direction_mark(text):
@ -61,7 +61,7 @@ if os.name == 'nt':
if lang: if lang:
os.environ['LANG'] = lang os.environ['LANG'] = lang
gettext.install(APP, DIR, unicode=False) gettext.install(APP, DIR)
if gettext._translations: if gettext._translations:
_translation = gettext._translations.values()[0] _translation = gettext._translations.values()[0]
else: else:

View File

@ -158,7 +158,7 @@ def send_cert_request(con, to_jid):
pubkey = iq.setTag('pubkeys') pubkey = iq.setTag('pubkeys')
pubkey.setNamespace(nbxmpp.NS_PUBKEY_PUBKEY) pubkey.setNamespace(nbxmpp.NS_PUBKEY_PUBKEY)
con.connection.send(iq) con.connection.send(iq)
return unicode(id_) return str(id_)
# the following code is partly due to pyopenssl examples # the following code is partly due to pyopenssl examples

View File

@ -46,7 +46,7 @@ def kwallet_get(folder, entry):
folder: The top-level category to use (normally the programme name) folder: The top-level category to use (normally the programme name)
entry: The key of the entry to retrieve entry: The key of the entry to retrieve
Returns the passphrase as unicode, False if it cannot be found, Returns the passphrase, False if it cannot be found,
or None if an error occured. or None if an error occured.
""" """
p = subprocess.Popen(["kwalletcli", "-q", "-f", folder.encode('utf-8'), p = subprocess.Popen(["kwalletcli", "-q", "-f", folder.encode('utf-8'),

View File

@ -884,8 +884,7 @@ class Logger:
# ..., 'FEAT', feature1, feature2, ...).join(' ')) # ..., 'FEAT', feature1, feature2, ...).join(' '))
# NOTE: if there's a need to do more gzip, put that to a function # NOTE: if there's a need to do more gzip, put that to a function
try: try:
data = GzipFile(fileobj=StringIO(str(data))).read().decode( data = GzipFile(fileobj=StringIO(str(data))).read().split('\0')
'utf-8').split('\0')
except IOError: except IOError:
# This data is corrupted. It probably contains non-ascii chars # This data is corrupted. It probably contains non-ascii chars
to_be_removed.append((hash_method, hash_)) to_be_removed.append((hash_method, hash_))
@ -927,7 +926,6 @@ class Logger:
# if there's a need to do more gzip, put that to a function # if there's a need to do more gzip, put that to a function
string = StringIO() string = StringIO()
gzip = GzipFile(fileobj=string, mode='w') gzip = GzipFile(fileobj=string, mode='w')
data = data.encode('utf-8') # the gzip module can't handle unicode objects
gzip.write(data) gzip.write(data)
gzip.close() gzip.close()
data = string.getvalue() data = string.getvalue()

View File

@ -19,7 +19,7 @@
## ##
import logging import logging
import i18n from common import i18n
def parseLogLevel(arg): def parseLogLevel(arg):
""" """

View File

@ -96,7 +96,7 @@ class ConnectionArchive:
def get_item_pref(self, jid): def get_item_pref(self, jid):
jid = nbxmpp.JID(jid) jid = nbxmpp.JID(jid)
if unicode(jid) in self.items: if str(jid) in self.items:
return self.items[jid] return self.items[jid]
if jid.getStripped() in self.items: if jid.getStripped() in self.items:

View File

@ -87,19 +87,12 @@ class OptionsParser:
if value is None: if value is None:
return return
# convert to utf8 before writing to file if needed # convert to utf8 before writing to file if needed
if isinstance(value, unicode): value = str(value)
value = value.encode('utf-8')
else:
value = str(value)
if isinstance(opt, unicode):
opt = opt.encode('utf-8')
s = '' s = ''
if parents: if parents:
if len(parents) == 1: if len(parents) == 1:
return return
for p in parents: for p in parents:
if isinstance(p, unicode):
p = p.encode('utf-8')
s += p + '.' s += p + '.'
s += opt s += opt
fd.write(s + ' = ' + value + '\n') fd.write(s + ' = ' + value + '\n')

View File

@ -163,7 +163,7 @@ class ConnectionBytestream:
session.approve_content('file', content.name) session.approve_content('file', content.name)
return return
iq = nbxmpp.Iq(to=unicode(file_props.sender), typ='result') iq = nbxmpp.Iq(to=file_props.sender, typ='result')
iq.setAttr('id', file_props.request_id) iq.setAttr('id', file_props.request_id)
si = iq.setTag('si', namespace=nbxmpp.NS_SI) si = iq.setTag('si', namespace=nbxmpp.NS_SI)
if file_props.offset: if file_props.offset:
@ -195,7 +195,7 @@ class ConnectionBytestream:
jingle = self._sessions[file_props.sid] jingle = self._sessions[file_props.sid]
jingle.cancel_session() jingle.cancel_session()
return return
iq = nbxmpp.Iq(to=unicode(file_props.sender), typ='error') iq = nbxmpp.Iq(to=file_props.sender, typ='error')
iq.setAttr('id', file_props.request_id) iq.setAttr('id', file_props.request_id)
if code == '400' and typ in ('stream', 'profile'): if code == '400' and typ in ('stream', 'profile'):
name = 'bad-request' name = 'bad-request'
@ -296,7 +296,7 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
for file_props in FilesProp.getAllFileProp(): for file_props in FilesProp.getAllFileProp():
if is_transfer_stopped(file_props): if is_transfer_stopped(file_props):
continue continue
receiver_jid = unicode(file_props.receiver) receiver_jid = file_props.receiver
if contact.get_full_jid() == receiver_jid: if contact.get_full_jid() == receiver_jid:
file_props.error = -5 file_props.error = -5
self.remove_transfer(file_props) self.remove_transfer(file_props)
@ -305,7 +305,7 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
gajim.nec.push_incoming_event(FileRequestErrorEvent(None, gajim.nec.push_incoming_event(FileRequestErrorEvent(None,
conn=self, jid=contact.jid, file_props=file_props, conn=self, jid=contact.jid, file_props=file_props,
error_msg='')) error_msg=''))
sender_jid = unicode(file_props.sender) sender_jid = file_props.sender
if contact.get_full_jid() == sender_jid: if contact.get_full_jid() == sender_jid:
file_props.error = -3 file_props.error = -3
self.remove_transfer(file_props) self.remove_transfer(file_props)
@ -354,11 +354,11 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
file_props.error = -5 file_props.error = -5
from common.connection_handlers_events import FileRequestErrorEvent from common.connection_handlers_events import FileRequestErrorEvent
gajim.nec.push_incoming_event(FileRequestErrorEvent(None, conn=self, gajim.nec.push_incoming_event(FileRequestErrorEvent(None, conn=self,
jid=unicode(receiver), file_props=file_props, error_msg='')) jid=receiver, file_props=file_props, error_msg=''))
self._connect_error(unicode(receiver), file_props.sid, self._connect_error(receiver, file_props.sid,
file_props.sid, code=406) file_props.sid, code=406)
else: else:
iq = nbxmpp.Iq(to=unicode(receiver), typ='set') iq = nbxmpp.Iq(to=receiver, typ='set')
file_props.request_id = 'id_' + file_props.sid file_props.request_id = 'id_' + file_props.sid
iq.setID(file_props.request_id) iq.setID(file_props.request_id)
query = iq.setTag('query', namespace=nbxmpp.NS_BYTESTREAM) query = iq.setTag('query', namespace=nbxmpp.NS_BYTESTREAM)
@ -374,7 +374,7 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
for host in hosts: for host in hosts:
streamhost = nbxmpp.Node(tag='streamhost') streamhost = nbxmpp.Node(tag='streamhost')
query.addChild(node=streamhost) query.addChild(node=streamhost)
streamhost.setAttr('port', unicode(port)) streamhost.setAttr('port', str(port))
streamhost.setAttr('host', host) streamhost.setAttr('host', host)
streamhost.setAttr('jid', sender) streamhost.setAttr('jid', sender)
@ -489,8 +489,8 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
def _add_proxy_streamhosts_to_query(self, query, file_props): def _add_proxy_streamhosts_to_query(self, query, file_props):
proxyhosts = self._get_file_transfer_proxies_from_config(file_props) proxyhosts = self._get_file_transfer_proxies_from_config(file_props)
if proxyhosts: if proxyhosts:
file_props.proxy_receiver = unicode(file_props.receiver) file_props.proxy_receiver = file_props.receiver
file_props.proxy_sender = unicode(file_props.sender) file_props.proxy_sender = file_props.sender
file_props.proxyhosts = proxyhosts file_props.proxyhosts = proxyhosts
for proxyhost in proxyhosts: for proxyhost in proxyhosts:
@ -518,12 +518,12 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
continue continue
host_dict = { host_dict = {
'state': 0, 'state': 0,
'target': unicode(file_props.receiver), 'target': file_props.receiver,
'id': file_props.sid, 'id': file_props.sid,
'sid': file_props.sid, 'sid': file_props.sid,
'initiator': proxy, 'initiator': proxy,
'host': host, 'host': host,
'port': unicode(_port), 'port': str(_port),
'jid': jid 'jid': jid
} }
proxyhost_dicts.append(host_dict) proxyhost_dicts.append(host_dict)
@ -563,7 +563,7 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
iq = nbxmpp.Iq(to=to, typ='error') iq = nbxmpp.Iq(to=to, typ='error')
iq.setAttr('id', file_props.sid) iq.setAttr('id', file_props.sid)
err = iq.setTag('error') err = iq.setTag('error')
err.setAttr('code', unicode(code)) err.setAttr('code', str(code))
err.setData(msg) err.setData(msg)
self.connection.send(iq) self.connection.send(iq)
if code == 404: if code == 404:
@ -593,7 +593,7 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
# register xmpppy handlers for bytestream and FT stanzas # register xmpppy handlers for bytestream and FT stanzas
def _bytestreamErrorCB(self, con, iq_obj): def _bytestreamErrorCB(self, con, iq_obj):
id_ = unicode(iq_obj.getAttr('id')) id_ = iq_obj.getAttr('id')
frm = helpers.get_full_jid_from_iq(iq_obj) frm = helpers.get_full_jid_from_iq(iq_obj)
query = iq_obj.getTag('query') query = iq_obj.getTag('query')
gajim.proxy65_manager.error_cb(frm, query) gajim.proxy65_manager.error_cb(frm, query)
@ -609,10 +609,10 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
raise nbxmpp.NodeProcessed raise nbxmpp.NodeProcessed
def _bytestreamSetCB(self, con, iq_obj): def _bytestreamSetCB(self, con, iq_obj):
target = unicode(iq_obj.getAttr('to')) target = iq_obj.getAttr('to')
id_ = unicode(iq_obj.getAttr('id')) id_ = iq_obj.getAttr('id')
query = iq_obj.getTag('query') query = iq_obj.getTag('query')
sid = unicode(query.getAttr('sid')) sid = query.getAttr('sid')
file_props = FilesProp.getFileProp(self.name, sid) file_props = FilesProp.getFileProp(self.name, sid)
streamhosts = [] streamhosts = []
for item in query.getChildren(): for item in query.getChildren():
@ -657,7 +657,7 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
def _ResultCB(self, con, iq_obj): def _ResultCB(self, con, iq_obj):
# if we want to respect xep-0065 we have to check for proxy # if we want to respect xep-0065 we have to check for proxy
# activation result in any result iq # activation result in any result iq
real_id = unicode(iq_obj.getAttr('id')) real_id = iq_obj.getAttr('id')
if not real_id.startswith('au_'): if not real_id.startswith('au_'):
return return
frm = self._ft_get_from(iq_obj) frm = self._ft_get_from(iq_obj)
@ -671,7 +671,7 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
def _bytestreamResultCB(self, con, iq_obj): def _bytestreamResultCB(self, con, iq_obj):
frm = self._ft_get_from(iq_obj) frm = self._ft_get_from(iq_obj)
real_id = unicode(iq_obj.getAttr('id')) real_id = iq_obj.getAttr('id')
query = iq_obj.getTag('query') query = iq_obj.getTag('query')
gajim.proxy65_manager.resolve_result(frm, query) gajim.proxy65_manager.resolve_result(frm, query)
@ -692,7 +692,7 @@ class ConnectionSocks5Bytestream(ConnectionBytestream):
raise nbxmpp.NodeProcessed raise nbxmpp.NodeProcessed
for host in file_props.proxyhosts: for host in file_props.proxyhosts:
if host['initiator'] == frm and \ if host['initiator'] == frm and \
unicode(query.getAttr('sid')) == file_props.sid: query.getAttr('sid') == file_props.sid:
gajim.socks5queue.activate_proxy(host['idx']) gajim.socks5queue.activate_proxy(host['idx'])
break break
raise nbxmpp.NodeProcessed raise nbxmpp.NodeProcessed
@ -983,7 +983,7 @@ class ConnectionIBBytestream(ConnectionBytestream):
class ConnectionSocks5BytestreamZeroconf(ConnectionSocks5Bytestream): class ConnectionSocks5BytestreamZeroconf(ConnectionSocks5Bytestream):
def _ft_get_from(self, iq_obj): def _ft_get_from(self, iq_obj):
return unicode(iq_obj.getFrom()) return iq_obj.getFrom()
def _ft_get_our_jid(self): def _ft_get_our_jid(self):
return gajim.get_jid_from_account(self.name) return gajim.get_jid_from_account(self.name)

View File

@ -117,7 +117,7 @@ class ProxyResolver:
""" """
self.host = str(host) self.host = str(host)
self.port = int(port) self.port = int(port)
self.jid = unicode(jid) self.jid = str(jid)
if not self.testit: if not self.testit:
self.state = S_FINISHED self.state = S_FINISHED
return return

View File

@ -418,19 +418,12 @@ class P2PConnection(IdleObject, PlugIn):
""" """
Append stanza to the queue of messages to be send if now is False, else Append stanza to the queue of messages to be send if now is False, else
send it instantly send it instantly
If supplied data is unicode string, encode it to UTF-8.
""" """
if self.state <= 0: if self.state <= 0:
return return
r = packet r = packet
if isinstance(r, unicode):
r = r.encode('utf-8')
elif not isinstance(r, str):
r = ustr(r).encode('utf-8')
if now: if now:
self.sendqueue.insert(0, (r, is_message)) self.sendqueue.insert(0, (r, is_message))
self._do_send() self._do_send()
@ -737,7 +730,7 @@ class ClientZeroconf:
def send(self, stanza, is_message=False, now=False, on_ok=None, def send(self, stanza, is_message=False, now=False, on_ok=None,
on_not_ok=None): on_not_ok=None):
stanza.setFrom(self.roster.zeroconf.name) stanza.setFrom(self.roster.zeroconf.name)
to = unicode(stanza.getTo()) to = stanza.getTo()
to = gajim.get_jid_without_resource(to) to = gajim.get_jid_without_resource(to)
try: try:
@ -802,7 +795,7 @@ class ClientZeroconf:
def on_ok(_waitid): def on_ok(_waitid):
# if timeout: # if timeout:
# self._owner.set_timeout(timeout) # self._owner.set_timeout(timeout)
to = unicode(stanza.getTo()) to = stanza.getTo()
to = gajim.get_jid_without_resource(to) to = gajim.get_jid_without_resource(to)
try: try:

View File

@ -91,7 +91,7 @@ class ConnectionZeroconf(CommonConnection, ConnectionHandlersZeroconf):
'is_zeroconf', True) 'is_zeroconf', True)
gajim.config.set_per('accounts', gajim.ZEROCONF_ACC_NAME, gajim.config.set_per('accounts', gajim.ZEROCONF_ACC_NAME,
'use_ft_proxies', False) 'use_ft_proxies', False)
self.host = unicode(socket.gethostname(), locale.getpreferredencoding()) self.host = socket.gethostname()
gajim.config.set_per('accounts', gajim.ZEROCONF_ACC_NAME, 'hostname', gajim.config.set_per('accounts', gajim.ZEROCONF_ACC_NAME, 'hostname',
self.host) self.host)
self.port = gajim.config.get_per('accounts', gajim.ZEROCONF_ACC_NAME, self.port = gajim.config.get_per('accounts', gajim.ZEROCONF_ACC_NAME,
@ -110,8 +110,7 @@ class ConnectionZeroconf(CommonConnection, ConnectionHandlersZeroconf):
'zeroconf_email') 'zeroconf_email')
if not self.username: if not self.username:
self.username = unicode(getpass.getuser(), self.username = getpass.getuser()
locale.getpreferredencoding())
gajim.config.set_per('accounts', gajim.ZEROCONF_ACC_NAME, 'name', gajim.config.set_per('accounts', gajim.ZEROCONF_ACC_NAME, 'name',
self.username) self.username)
else: else:
@ -427,7 +426,7 @@ class ConnectionZeroconf(CommonConnection, ConnectionHandlersZeroconf):
if realm == '': if realm == '':
if event == nbxmpp.transports_nb.DATA_ERROR: if event == nbxmpp.transports_nb.DATA_ERROR:
thread_id = data[1] thread_id = data[1]
frm = unicode(data[0]) frm = data[0]
session = self.get_or_create_session(frm, thread_id) session = self.get_or_create_session(frm, thread_id)
gajim.nec.push_incoming_event(MessageErrorEvent( gajim.nec.push_incoming_event(MessageErrorEvent(
None, conn=self, fjid=frm, error_code=-1, error_msg=_( None, conn=self, fjid=frm, error_code=-1, error_msg=_(

View File

@ -224,14 +224,7 @@ class Zeroconf:
return show return show
def avahi_txt(self): def avahi_txt(self):
utf8_dict = {} return self.avahi.dict_to_txt_array(self.txt)
for key in self.txt:
val = self.txt[key]
if isinstance(val, unicode):
utf8_dict[key] = val.encode('utf-8')
else:
utf8_dict[key] = val
return self.avahi.dict_to_txt_array(utf8_dict)
def create_service(self): def create_service(self):
try: try:

View File

@ -1355,11 +1355,11 @@ class ManageProxiesWindow:
model = self.proxies_treeview.get_model() model = self.proxies_treeview.get_model()
proxies = gajim.config.get_per('proxies') proxies = gajim.config.get_per('proxies')
i = 1 i = 1
while ('proxy' + unicode(i)) in proxies: while ('proxy' + str(i)) in proxies:
i += 1 i += 1
iter_ = model.append() iter_ = model.append()
model.set(iter_, 0, 'proxy' + unicode(i)) model.set(iter_, 0, 'proxy' + str(i))
gajim.config.add_per('proxies', 'proxy' + unicode(i)) gajim.config.add_per('proxies', 'proxy' + str(i))
self.proxies_treeview.set_cursor(model.get_path(iter_)) self.proxies_treeview.set_cursor(model.get_path(iter_))
def on_remove_proxy_button_clicked(self, widget): def on_remove_proxy_button_clicked(self, widget):
@ -1453,7 +1453,7 @@ class ManageProxiesWindow:
self.xml.get_object('proxy_table').set_sensitive(True) self.xml.get_object('proxy_table').set_sensitive(True)
proxyhost_entry.set_text(gajim.config.get_per('proxies', proxy, proxyhost_entry.set_text(gajim.config.get_per('proxies', proxy,
'host')) 'host'))
proxyport_entry.set_text(unicode(gajim.config.get_per('proxies', proxyport_entry.set_text(str(gajim.config.get_per('proxies',
proxy, 'port'))) proxy, 'port')))
proxyuser_entry.set_text(gajim.config.get_per('proxies', proxy, proxyuser_entry.set_text(gajim.config.get_per('proxies', proxy,
'user')) 'user'))
@ -1955,7 +1955,7 @@ class AccountsWindow:
if not custom_port: if not custom_port:
custom_port = 5222 custom_port = 5222
gajim.config.set_per('accounts', account, 'custom_port', custom_port) gajim.config.set_per('accounts', account, 'custom_port', custom_port)
self.xml.get_object('custom_port_entry1').set_text(unicode(custom_port)) self.xml.get_object('custom_port_entry1').set_text(str(custom_port))
# Personal tab # Personal tab
gpg_key_label = self.xml.get_object('gpg_key_label1') gpg_key_label = self.xml.get_object('gpg_key_label1')
@ -3288,13 +3288,13 @@ class ManageBookmarksWindow:
return return
for account in self.treestore: for account in self.treestore:
account_unicode = account[1] acct = account[1]
gajim.connections[account_unicode].bookmarks = [] gajim.connections[acct].bookmarks = []
for bm in account.iterchildren(): for bm in account.iterchildren():
# Convert True/False/None to '1' or '0' # Convert True/False/None to '1' or '0'
autojoin = unicode(int(bm[3])) autojoin = str(int(bm[3]))
minimize = unicode(int(bm[4])) minimize = str(int(bm[4]))
name = bm[1] name = bm[1]
jid = bm[2] jid = bm[2]
pw = bm[5] pw = bm[5]
@ -3305,9 +3305,9 @@ class ManageBookmarksWindow:
'minimize': minimize, 'password': pw, 'nick': nick, 'minimize': minimize, 'password': pw, 'nick': nick,
'print_status': bm[7]} 'print_status': bm[7]}
gajim.connections[account_unicode].bookmarks.append(bmdict) gajim.connections[acct].bookmarks.append(bmdict)
gajim.connections[account_unicode].store_bookmarks() gajim.connections[acct].store_bookmarks()
gajim.interface.roster.set_actions_menu_needs_rebuild() gajim.interface.roster.set_actions_menu_needs_rebuild()
self.window.destroy() self.window.destroy()

View File

@ -1313,10 +1313,6 @@ class ConversationTextview(GObject.GObject):
timestamp_str = helpers.from_one_line(timestamp_str) timestamp_str = helpers.from_one_line(timestamp_str)
format_ += timestamp_str format_ += timestamp_str
tim_format = time.strftime(format_, tim) tim_format = time.strftime(format_, tim)
if locale.getpreferredencoding() not in ('KOI8-R', 'cp1251'):
# if tim_format comes as unicode because of day_str.
# we convert it to the encoding that we want (and that is utf-8)
tim_format = helpers.ensure_utf8_string(tim_format)
return tim_format return tim_format
def detect_other_text_tag(self, text, kind): def detect_other_text_tag(self, text, kind):

View File

@ -113,7 +113,7 @@ class DataFormWidget(Gtk.Alignment, object):
def get_title(self): def get_title(self):
""" """
Get the title of data form, as a unicode object. If no title or no form, Get the title of data form. If no title or no form,
returns ''. Useful for setting window title returns ''. Useful for setting window title
""" """
if self._data_form is not None: if self._data_form is not None:

View File

@ -3110,7 +3110,7 @@ class SingleMessageWindow:
def update_char_counter(self, widget): def update_char_counter(self, widget):
characters_no = self.message_tv_buffer.get_char_count() characters_no = self.message_tv_buffer.get_char_count()
self.count_chars_label.set_text(unicode(characters_no)) self.count_chars_label.set_text(characters_no)
def send_single_message(self): def send_single_message(self):
if gajim.connections[self.account].connected <= 1: if gajim.connections[self.account].connected <= 1:

View File

@ -153,12 +153,12 @@ class FileTransfersWindow:
for file_props in allfp: for file_props in allfp:
if file_props.type_ == 's' and file_props.tt_account == account: if file_props.type_ == 's' and file_props.tt_account == account:
# 'account' is the sender # 'account' is the sender
receiver_jid = unicode(file_props.receiver).split('/')[0] receiver_jid = file_props.receiver.split('/')[0]
if jid == receiver_jid and not is_transfer_stopped(file_props): if jid == receiver_jid and not is_transfer_stopped(file_props):
active_transfers[0].append(file_props) active_transfers[0].append(file_props)
elif file_props.type_ == 'r' and file_props.tt_account == account: elif file_props.type_ == 'r' and file_props.tt_account == account:
# 'account' is the recipient # 'account' is the recipient
sender_jid = unicode(file_props.sender).split('/')[0] sender_jid = file_props.sender.split('/')[0]
if jid == sender_jid and not is_transfer_stopped(file_props): if jid == sender_jid and not is_transfer_stopped(file_props):
active_transfers[1].append(file_props) active_transfers[1].append(file_props)
else: else:
@ -188,7 +188,7 @@ class FileTransfersWindow:
sectext += '\n\t' + _('Size: %s') % \ sectext += '\n\t' + _('Size: %s') % \
helpers.convert_bytes(file_props.size) helpers.convert_bytes(file_props.size)
if file_props.type_ == 'r': if file_props.type_ == 'r':
jid = unicode(file_props.sender).split('/')[0] jid = file_props.sender.split('/')[0]
sender_name = gajim.contacts.get_first_contact_from_jid( sender_name = gajim.contacts.get_first_contact_from_jid(
file_props.tt_account, jid).get_shown_name() file_props.tt_account, jid).get_shown_name()
sender = sender_name sender = sender_name
@ -198,7 +198,7 @@ class FileTransfersWindow:
sectext += '\n\t' + _('Sender: %s') % sender sectext += '\n\t' + _('Sender: %s') % sender
sectext += '\n\t' + _('Recipient: ') sectext += '\n\t' + _('Recipient: ')
if file_props.type_ == 's': if file_props.type_ == 's':
jid = unicode(file_props.receiver).split('/')[0] jid = file_props.receiver.split('/')[0]
receiver_name = gajim.contacts.get_first_contact_from_jid( receiver_name = gajim.contacts.get_first_contact_from_jid(
file_props.tt_account, jid).get_shown_name() file_props.tt_account, jid).get_shown_name()
recipient = receiver_name recipient = receiver_name
@ -533,7 +533,7 @@ class FileTransfersWindow:
_str += ' ' _str += ' '
if percent < 10: if percent < 10:
_str += ' ' _str += ' '
_str += unicode(percent) + '% \n' _str += str(percent) + '% \n'
return _str return _str
def _format_time(self, _time): def _format_time(self, _time):
@ -585,7 +585,7 @@ class FileTransfersWindow:
other = file_props.sender other = file_props.sender
else: # we send a file else: # we send a file
other = file_props.receiver other = file_props.receiver
if isinstance(other, unicode): if isinstance(other, str):
jid = gajim.get_jid_without_resource(other) jid = gajim.get_jid_without_resource(other)
else: # It's a Contact instance else: # It's a Contact instance
jid = other.jid jid = other.jid
@ -713,7 +713,7 @@ class FileTransfersWindow:
file_props.type_ = 's' file_props.type_ = 's'
file_props.desc = file_desc file_props.desc = file_desc
file_props.elapsed_time = 0 file_props.elapsed_time = 0
file_props.size = unicode(stat[6]) file_props.size = str(stat[6])
file_props.sender = account file_props.sender = account
file_props.receiver = contact file_props.receiver = contact
file_props.tt_account = account file_props.tt_account = account

View File

@ -354,10 +354,7 @@ class GajimRemote:
elif self.command == 'list_accounts': elif self.command == 'list_accounts':
if isinstance(res, list): if isinstance(res, list):
for account in res: for account in res:
if isinstance(account, unicode): print(account)
print(account.encode(PREFERRED_ENCODING))
else:
print(account)
elif self.command == 'account_info': elif self.command == 'account_info':
if res: if res:
print(self.print_info(0, res, True)) print(self.print_info(0, res, True))
@ -368,14 +365,11 @@ class GajimRemote:
pref_keys = sorted(res.keys()) pref_keys = sorted(res.keys())
for pref_key in pref_keys: for pref_key in pref_keys:
result = '%s = %s' % (pref_key, res[pref_key]) result = '%s = %s' % (pref_key, res[pref_key])
if isinstance(result, unicode): print(result)
print(result.encode(PREFERRED_ENCODING))
else:
print(result)
elif self.command == 'contact_info': elif self.command == 'contact_info':
print(self.print_info(0, res, True)) print(self.print_info(0, res, True))
elif res: elif res:
print(unicode(res).encode(PREFERRED_ENCODING)) print(res)
def check_gajim_running(self): def check_gajim_running(self):
if not self.sbus: if not self.sbus:
@ -470,7 +464,7 @@ class GajimRemote:
ret_str +='\t' ret_str +='\t'
elif isinstance(val, int): elif isinstance(val, int):
ret_str +='\t' + str(val) ret_str +='\t' + str(val)
elif isinstance(val, (str, unicode)): elif isinstance(val, str):
ret_str +='\t' + val ret_str +='\t' + val
elif isinstance(val, (list, tuple)): elif isinstance(val, (list, tuple)):
res = '' res = ''
@ -485,7 +479,7 @@ class GajimRemote:
for key in prop_dict.keys(): for key in prop_dict.keys():
val = prop_dict[key] val = prop_dict[key]
spacing = ' ' * level * 4 spacing = ' ' * level * 4
if isinstance(val, (unicode, int, str)): if isinstance(val, (int, str)):
if val is not None: if val is not None:
val = val.strip() val = val.strip()
ret_str += '%s%-10s: %s\n' % (spacing, key, val) ret_str += '%s%-10s: %s\n' % (spacing, key, val)

View File

@ -84,7 +84,7 @@ if os.name == 'nt':
os.environ['LANG'] = lang os.environ['LANG'] = lang
gettext.bindtextdomain(APP, DIR) gettext.bindtextdomain(APP, DIR)
gettext.textdomain(APP) gettext.textdomain(APP)
gettext.install(APP, DIR, unicode=True) gettext.install(APP, DIR)
locale.setlocale(locale.LC_ALL, '') locale.setlocale(locale.LC_ALL, '')
import ctypes import ctypes
@ -155,12 +155,8 @@ def parseOpts():
import locale import locale
profile, config_path = parseOpts() profile, config_path = parseOpts()
if config_path:
config_path = unicode(config_path, locale.getpreferredencoding())
del parseOpts del parseOpts
profile = unicode(profile, locale.getpreferredencoding())
import common.configpaths import common.configpaths
common.configpaths.gajimpaths.init(config_path) common.configpaths.gajimpaths.init(config_path)
del config_path del config_path

View File

@ -168,10 +168,10 @@ class GajimThemesWindow:
# don't confuse translators # don't confuse translators
theme_name = _('theme name') theme_name = _('theme name')
theme_name_ns = theme_name.replace(' ', '_') theme_name_ns = theme_name.replace(' ', '_')
while theme_name_ns + unicode(i) in gajim.config.get_per('themes'): while theme_name_ns + str(i) in gajim.config.get_per('themes'):
i += 1 i += 1
model.set_value(iter_, 0, theme_name + unicode(i)) model.set_value(iter_, 0, theme_name + str(i))
gajim.config.add_per('themes', theme_name_ns + unicode(i)) gajim.config.add_per('themes', theme_name_ns + str(i))
self.themes_tree.get_selection().select_iter(iter_) self.themes_tree.get_selection().select_iter(iter_)
col = self.themes_tree.get_column(0) col = self.themes_tree.get_column(0)
path = model.get_path(iter_) path = model.get_path(iter_)

View File

@ -687,7 +687,7 @@ class GroupchatControl(ChatControlBase):
if num_unread == 1: if num_unread == 1:
unread = '*' unread = '*'
elif num_unread > 1: elif num_unread > 1:
unread = '[' + unicode(num_unread) + ']' unread = '[' + str(num_unread) + ']'
label_str = unread + label_str label_str = unread + label_str
return (label_str, color) return (label_str, color)
@ -1048,9 +1048,7 @@ class GroupchatControl(ChatControlBase):
return None return None
def print_old_conversation(self, text, contact='', tim=None, xhtml = None, def print_old_conversation(self, text, contact='', tim=None, xhtml = None,
displaymarking=None): displaymarking=None):
if isinstance(text, str):
text = unicode(text, 'utf-8')
if contact: if contact:
if contact == self.nick: # it's us if contact == self.nick: # it's us
kind = 'outgoing' kind = 'outgoing'
@ -1076,8 +1074,6 @@ class GroupchatControl(ChatControlBase):
(contact = 'info' in such a case). (contact = 'info' in such a case).
If contact is not set: it's a message from the server or help. If contact is not set: it's a message from the server or help.
""" """
if isinstance(text, str):
text = unicode(text, 'utf-8')
other_tags_for_name = [] other_tags_for_name = []
other_tags_for_text = [] other_tags_for_text = []
if contact: if contact:
@ -2200,7 +2196,7 @@ class GroupchatControl(ChatControlBase):
self.nick_hits = [] # clear the hit list self.nick_hits = [] # clear the hit list
list_nick = gajim.contacts.get_nick_list(self.account, list_nick = gajim.contacts.get_nick_list(self.account,
self.room_jid) self.room_jid)
list_nick.sort(key=unicode.lower) # case-insensitive sort list_nick.sort(key=str.lower) # case-insensitive sort
if begin == '': if begin == '':
# empty message, show lasts nicks that highlighted us first # empty message, show lasts nicks that highlighted us first
for nick in self.attention_list: for nick in self.attention_list:

View File

@ -164,7 +164,7 @@ class Interface:
def handle_event_iq_error(self, obj): def handle_event_iq_error(self, obj):
#('ERROR_ANSWER', account, (id_, fjid, errmsg, errcode)) #('ERROR_ANSWER', account, (id_, fjid, errmsg, errcode))
if unicode(obj.errcode) in ('400', '403', '406') and obj.id_: if str(obj.errcode) in ('400', '403', '406') and obj.id_:
# show the error dialog # show the error dialog
ft = self.instances['file_transfers'] ft = self.instances['file_transfers']
sid = obj.id_ sid = obj.id_
@ -172,7 +172,7 @@ class Interface:
sid = obj.id_[3:] sid = obj.id_[3:]
file_props = FilesProp.getFileProp(obj.conn.name, sid) file_props = FilesProp.getFileProp(obj.conn.name, sid)
if file_props : if file_props :
if unicode(obj.errcode) == '400': if str(obj.errcode) == '400':
file_props.error = -3 file_props.error = -3
else: else:
file_props.error = -4 file_props.error = -4
@ -181,7 +181,7 @@ class Interface:
error_msg=obj.errmsg)) error_msg=obj.errmsg))
obj.conn.disconnect_transfer(file_props) obj.conn.disconnect_transfer(file_props)
return return
elif unicode(obj.errcode) == '404': elif str(obj.errcode) == '404':
sid = obj.id_ sid = obj.id_
if len(obj.id_) > 3 and obj.id_[2] == '_': if len(obj.id_) > 3 and obj.id_[2] == '_':
sid = obj.id_[3:] sid = obj.id_[3:]
@ -951,7 +951,7 @@ class Interface:
ft_win = self.instances['file_transfers'] ft_win = self.instances['file_transfers']
if not file_props.hash_: if not file_props.hash_:
# We disn't get the hash, sender probably don't support that # We disn't get the hash, sender probably don't support that
jid = unicode(file_props.sender) jid = file_props.sender
self.popup_ft_result(account, jid, file_props) self.popup_ft_result(account, jid, file_props)
ft_win.set_status(file_props, 'ok') ft_win.set_status(file_props, 'ok')
h = Hashes() h = Hashes()
@ -963,7 +963,7 @@ class Interface:
file_.close() file_.close()
# If the hash we received and the hash of the file are the same, # If the hash we received and the hash of the file are the same,
# then the file is not corrupt # then the file is not corrupt
jid = unicode(file_props.sender) jid = file_props.sender
if file_props.hash_ == hash_: if file_props.hash_ == hash_:
GObject.idle_add(self.popup_ft_result, account, jid, file_props) GObject.idle_add(self.popup_ft_result, account, jid, file_props)
GObject.idle_add(ft_win.set_status, file_props, 'ok') GObject.idle_add(ft_win.set_status, file_props, 'ok')
@ -995,7 +995,7 @@ class Interface:
self.hashThread.start() self.hashThread.start()
gajim.socks5queue.remove_receiver(file_props.sid, True, True) gajim.socks5queue.remove_receiver(file_props.sid, True, True)
else: # we send a file else: # we send a file
jid = unicode(file_props.receiver) jid = file_props.receiver
gajim.socks5queue.remove_sender(file_props.sid, True, True) gajim.socks5queue.remove_sender(file_props.sid, True, True)
self.popup_ft_result(account, jid, file_props) self.popup_ft_result(account, jid, file_props)
@ -1042,7 +1042,7 @@ class Interface:
if file_props is not None: if file_props is not None:
if file_props.type_ == 'r': if file_props.type_ == 'r':
# get the name of the sender, as it is in the roster # get the name of the sender, as it is in the roster
sender = unicode(file_props.sender).split('/')[0] sender = file_props.sender.split('/')[0]
name = gajim.contacts.get_first_contact_from_jid(account, name = gajim.contacts.get_first_contact_from_jid(account,
sender).get_shown_name() sender).get_shown_name()
filename = os.path.basename(file_props.file_name) filename = os.path.basename(file_props.file_name)

View File

@ -498,7 +498,7 @@ class MessageWindow(object):
unread_str = '' unread_str = ''
if unread > 1: if unread > 1:
unread_str = '[' + unicode(unread) + '] ' unread_str = '[' + str(unread) + '] '
elif unread == 1: elif unread == 1:
unread_str = '* ' unread_str = '* '
else: else:
@ -693,10 +693,8 @@ class MessageWindow(object):
Return the MessageControl for jid or n, where n is a notebook page index. Return the MessageControl for jid or n, where n is a notebook page index.
When key is an int index acct may be None When key is an int index acct may be None
""" """
if isinstance(key, str):
key = unicode(key, 'utf-8')
if isinstance(key, unicode): if isinstance(key, str):
jid = key jid = key
try: try:
return self._controls[acct][jid] return self._controls[acct][jid]

View File

@ -46,7 +46,7 @@ class GajimPlugin(object):
Will be shown in plugins management GUI. Will be shown in plugins management GUI.
:type: unicode :type: str
''' '''
short_name = '' short_name = ''
''' '''
@ -54,7 +54,7 @@ class GajimPlugin(object):
Used for quick indentification of plugin. Used for quick indentification of plugin.
:type: unicode :type: str
:todo: decide whether we really need this one, because class name (with :todo: decide whether we really need this one, because class name (with
module name) can act as such short name module name) can act as such short name
@ -63,7 +63,7 @@ class GajimPlugin(object):
''' '''
Version of plugin. Version of plugin.
:type: unicode :type: str
:todo: decide how to compare version between each other (which one :todo: decide how to compare version between each other (which one
is higher). Also rethink: do we really need to compare versions is higher). Also rethink: do we really need to compare versions
@ -75,7 +75,7 @@ class GajimPlugin(object):
''' '''
Plugin description. Plugin description.
:type: unicode :type: str
:todo: should be allow rich text here (like HTML or reStructuredText)? :todo: should be allow rich text here (like HTML or reStructuredText)?
''' '''
@ -83,7 +83,7 @@ class GajimPlugin(object):
''' '''
Plugin authors. Plugin authors.
:type: [] of unicode :type: [] of str
:todo: should we decide on any particular format of author strings? :todo: should we decide on any particular format of author strings?
Especially: should we force format of giving author's e-mail? Especially: should we force format of giving author's e-mail?
@ -92,7 +92,7 @@ class GajimPlugin(object):
''' '''
URL to plug-in's homepage. URL to plug-in's homepage.
:type: unicode :type: str
:todo: should we check whether provided string is valid URI? (Maybe :todo: should we check whether provided string is valid URI? (Maybe
using 'property') using 'property')
@ -120,7 +120,7 @@ class GajimPlugin(object):
Values are tuples: (default_value, option_description). The first one can Values are tuples: (default_value, option_description). The first one can
be anything (this is the advantage of using shelve/pickle instead of be anything (this is the advantage of using shelve/pickle instead of
custom-made config I/O handling); the second one should be unicode (gettext custom-made config I/O handling); the second one should be str (gettext
can be used if need and/or translation is planned). can be used if need and/or translation is planned).
:type: {} of 2-element tuples :type: {} of 2-element tuples

View File

@ -158,7 +158,7 @@ class PluginManager(object):
active yet). active yet).
:param gui_extpoint_name: name of GUI extension point. :param gui_extpoint_name: name of GUI extension point.
:type gui_extpoint_name: unicode :type gui_extpoint_name: str
:param args: parameters to be passed to extension point handlers :param args: parameters to be passed to extension point handlers
(typically and object that invokes `gui_extension_point`; (typically and object that invokes `gui_extension_point`;
however, this can be practically anything) however, this can be practically anything)
@ -209,7 +209,7 @@ class PluginManager(object):
freedom, but is this necessary? freedom, but is this necessary?
:param gui_extpoint_name: name of GUI extension point. :param gui_extpoint_name: name of GUI extension point.
:type gui_extpoint_name: unicode :type gui_extpoint_name: str
:param args: arguments that `PluginManager.gui_extension_point` was :param args: arguments that `PluginManager.gui_extension_point` was
called with for this extension point. This is used (along with called with for this extension point. This is used (along with
extension point name) to identify element to be removed. extension point name) to identify element to be removed.
@ -394,7 +394,7 @@ class PluginManager(object):
Scans given directory for plugin classes. Scans given directory for plugin classes.
:param path: directory to scan for plugins :param path: directory to scan for plugins
:type path: unicode :type path: str
:return: list of found plugin classes (subclasses of `GajimPlugin` :return: list of found plugin classes (subclasses of `GajimPlugin`
:rtype: [] of class objects :rtype: [] of class objects

View File

@ -72,7 +72,7 @@ def get_dbus_struct(obj):
""" """
if obj is None: if obj is None:
return DBUS_NONE() return DBUS_NONE()
if isinstance(obj, (unicode, str)): if isinstance(obj, str):
return DBUS_STRING(obj) return DBUS_STRING(obj)
if isinstance(obj, int): if isinstance(obj, int):
return DBUS_INT32(obj) return DBUS_INT32(obj)
@ -613,8 +613,8 @@ class SignalObject(dbus.service.Object):
""" """
Get vcard info for a contact. Return cached value of the vcard Get vcard info for a contact. Return cached value of the vcard
""" """
if not isinstance(jid, unicode): if not isinstance(jid, str):
jid = unicode(jid) jid = str(jid)
if not jid: if not jid:
raise dbus_support.MissingArgument() raise dbus_support.MissingArgument()
jid = self._get_real_jid(jid) jid = self._get_real_jid(jid)
@ -652,9 +652,9 @@ class SignalObject(dbus.service.Object):
result['name'] = DBUS_STRING(con.name) result['name'] = DBUS_STRING(con.name)
result['jid'] = DBUS_STRING(gajim.get_jid_from_account(con.name)) result['jid'] = DBUS_STRING(gajim.get_jid_from_account(con.name))
result['message'] = DBUS_STRING(con.status) result['message'] = DBUS_STRING(con.status)
result['priority'] = DBUS_STRING(unicode(con.priority)) result['priority'] = DBUS_STRING(str(con.priority))
result['resource'] = DBUS_STRING(unicode(gajim.config.get_per( result['resource'] = DBUS_STRING(gajim.config.get_per('accounts',
'accounts', con.name, 'resource'))) con.name, 'resource'))
return result return result
@dbus.service.method(INTERFACE, in_signature='s', out_signature='aa{sv}') @dbus.service.method(INTERFACE, in_signature='s', out_signature='aa{sv}')

View File

@ -1202,7 +1202,7 @@ class RosterWindow:
nb_connected_contact += 1 nb_connected_contact += 1
if nb_connected_contact > 1: if nb_connected_contact > 1:
# switch back to default writing direction # switch back to default writing direction
name += i18n.paragraph_direction_mark(unicode(name)) name += i18n.paragraph_direction_mark(name)
name += ' (%d)' % nb_connected_contact name += ' (%d)' % nb_connected_contact
# add status msg, if not empty, under contact name in # add status msg, if not empty, under contact name in
@ -3512,8 +3512,8 @@ class RosterWindow:
elif type_ == 'agent': elif type_ == 'agent':
self.on_remove_agent(widget, list_) self.on_remove_agent(widget, list_)
elif not (event.get_state() & (Gdk.ModifierType.CONTROL_MASK | Gdk.ModifierType.MOD1_MASK)) and\ elif not (event.get_state() & (Gdk.ModifierType.CONTROL_MASK | \
Gdk.keyval_to_unicode(event.keyval): Gdk.ModifierType.MOD1_MASK)) and Gdk.keyval_to_unicode(event.keyval):
# if we got unicode symbol without ctrl / alt # if we got unicode symbol without ctrl / alt
num = Gdk.keyval_to_unicode(event.keyval) num = Gdk.keyval_to_unicode(event.keyval)
self.enable_rfilter(unichr(num)) self.enable_rfilter(unichr(num))

View File

@ -235,13 +235,10 @@ class StatusTable:
self.current_row + 1) self.current_row + 1)
def get_status_info(self, resource, priority, show, status): def get_status_info(self, resource, priority, show, status):
str_status = resource + ' (' + unicode(priority) + ')' str_status = resource + ' (' + str(priority) + ')'
if status: if status:
status = status.strip() status = status.strip()
if status != '': if status != '':
# make sure 'status' is unicode before we send to to reduce_chars
if isinstance(status, str):
status = unicode(status, encoding='utf-8')
# reduce to 100 chars, 1 line # reduce to 100 chars, 1 line
status = helpers.reduce_chars_newlines(status, 100, 1) status = helpers.reduce_chars_newlines(status, 100, 1)
str_status = GObject.markup_escape_text(str_status) str_status = GObject.markup_escape_text(str_status)
@ -301,10 +298,6 @@ class NotificationAreaTooltip(BaseTooltip, StatusTable):
file_path = os.path.join(helpers.get_iconset_path(iconset), '16x16') file_path = os.path.join(helpers.get_iconset_path(iconset), '16x16')
for acct in accounts: for acct in accounts:
message = acct['message'] message = acct['message']
# before reducing the chars we should assure we send unicode, else
# there are possible pango TBs on 'set_markup'
if isinstance(message, str):
message = unicode(message, encoding = 'utf-8')
message = helpers.reduce_chars_newlines(message, 100, 1) message = helpers.reduce_chars_newlines(message, 100, 1)
message = GObject.markup_escape_text(message) message = GObject.markup_escape_text(message)
if acct['name'] in gajim.con_types and \ if acct['name'] in gajim.con_types and \
@ -606,7 +599,7 @@ class RosterTooltip(NotificationAreaTooltip):
if num_resources == 1 and contact.resource: if num_resources == 1 and contact.resource:
properties.append((_('Resource: '), properties.append((_('Resource: '),
GObject.markup_escape_text(contact.resource) +\ GObject.markup_escape_text(contact.resource) +\
' (' + unicode(contact.priority) + ')')) ' (' + str(contact.priority) + ')'))
if self.account and prim_contact.sub and prim_contact.sub != 'both' and\ if self.account and prim_contact.sub and prim_contact.sub != 'both' and\
prim_contact.jid not in gajim.gc_connected[self.account]: prim_contact.jid not in gajim.gc_connected[self.account]:
@ -670,7 +663,7 @@ class RosterTooltip(NotificationAreaTooltip):
vcard_current_row + 1, Gtk.AttachOptions.EXPAND | \ vcard_current_row + 1, Gtk.AttachOptions.EXPAND | \
Gtk.AttachOptions.FILL, vertical_fill, 0, 0) Gtk.AttachOptions.FILL, vertical_fill, 0, 0)
else: else:
if isinstance(property_[0], (unicode, str)): # FIXME: rm unicode? if isinstance(property_[0], str):
label.set_markup(property_[0]) label.set_markup(property_[0])
label.set_line_wrap(True) label.set_line_wrap(True)
else: else:
@ -743,7 +736,7 @@ class FileTransfersTooltip(BaseTooltip):
if file_props.type_ == 'r': if file_props.type_ == 'r':
type_ = _('Download') type_ = _('Download')
actor = _('Sender: ') actor = _('Sender: ')
sender = unicode(file_props.sender).split('/')[0] sender = file_props.sender.split('/')[0]
name = gajim.contacts.get_first_contact_from_jid( name = gajim.contacts.get_first_contact_from_jid(
file_props.tt_account, sender).get_shown_name() file_props.tt_account, sender).get_shown_name()
else: else:

View File

@ -408,10 +408,10 @@ class VcardWindow:
tt_text = _("There is no pending subscription request.") tt_text = _("There is no pending subscription request.")
eb.set_tooltip_text(tt_text) eb.set_tooltip_text(tt_text)
resources = '%s (%s)' % (self.contact.resource, unicode( resources = '%s (%s)' % (self.contact.resource, str(
self.contact.priority)) self.contact.priority))
uf_resources = self.contact.resource + _(' resource with priority ')\ uf_resources = self.contact.resource + _(' resource with priority ')\
+ unicode(self.contact.priority) + str(self.contact.priority)
if not self.contact.status: if not self.contact.status:
self.contact.status = '' self.contact.status = ''
@ -462,9 +462,9 @@ class VcardWindow:
for c in contact_list: for c in contact_list:
if c.resource != self.contact.resource: if c.resource != self.contact.resource:
resources += '\n%s (%s)' % (c.resource, resources += '\n%s (%s)' % (c.resource,
unicode(c.priority)) str(c.priority))
uf_resources += '\n' + c.resource + \ uf_resources += '\n' + c.resource + \
_(' resource with priority ') + unicode(c.priority) _(' resource with priority ') + str(c.priority)
if c.show not in ('offline', 'error'): if c.show not in ('offline', 'error'):
GObject.idle_add( GObject.idle_add(
gajim.connections[self.account].request_os_info, c.jid, gajim.connections[self.account].request_os_info, c.jid,
@ -584,10 +584,10 @@ class ZeroconfVcardWindow:
'</span></b>') '</span></b>')
self.xml.get_object('local_jid_label').set_text(self.contact.jid) self.xml.get_object('local_jid_label').set_text(self.contact.jid)
resources = '%s (%s)' % (self.contact.resource, unicode( resources = '%s (%s)' % (self.contact.resource, str(
self.contact.priority)) self.contact.priority))
uf_resources = self.contact.resource + _(' resource with priority ')\ uf_resources = self.contact.resource + _(' resource with priority ')\
+ unicode(self.contact.priority) + str(self.contact.priority)
if not self.contact.status: if not self.contact.status:
self.contact.status = '' self.contact.status = ''