"""
-__version__ = "1.3.2"
+__version__ = "1.4.0"
__author__ = "Oleg Broytman <phd@phdru.name>"
__copyright__ = "Copyright (C) 2004-2013 PhiloSoft Design"
__license__ = "GPL"
import sys, os, shutil
from time import sleep
-import xml.dom.minidom, locale
+import xml.dom.minidom
from tempfile import mkstemp, mkdtemp, _candidate_tempdir_list
+try:
+ import locale
+ use_locale = True
+except ImportError:
+ use_locale = False
+
+if use_locale:
+ # Get the default charset.
+ try:
+ lcAll = locale.getdefaultlocale()
+ except locale.Error, err:
+ print >>sys.stderr, "WARNING:", err
+ lcAll = []
+
+ if len(lcAll) == 2:
+ default_encoding = lcAll[1]
+ else:
+ try:
+ default_encoding = locale.getpreferredencoding()
+ except locale.Error, err:
+ print >>sys.stderr, "WARNING:", err
+ default_encoding = sys.getdefaultencoding()
+else:
+ default_encoding = sys.getdefaultencoding()
+
import logging
logger = logging.getLogger('obexftp-mcextfs')
logger.addHandler(logging.FileHandler(logfile_name))
locale.setlocale(locale.LC_ALL, '')
-charset = locale.getpreferredencoding()
# Parse ObexFTP XML directory listings
for entry in directories + files:
fullpath = "%s/%s" % (directory, entry.name)
- fullpath = fullpath.encode(charset)
+ fullpath = fullpath.encode(default_encoding)
if fullpath.startswith('//'): fullpath = fullpath[1:]
print entry.perm, "1 user group", entry.size, entry.mtime, fullpath
"""
-__version__ = "1.1.1"
+__version__ = "1.2.0"
__author__ = "Oleg Broytman <phd@phdru.name>"
__copyright__ = "Copyright (C) 2010-2013 PhiloSoft Design"
__license__ = "GPL"
-import locale, sys, os
+
+import sys, os
from eff_bdecode import decode
+try:
+ import locale
+ use_locale = True
+except ImportError:
+ use_locale = False
+
+if use_locale:
+ # Get the default charset.
+ try:
+ lcAll = locale.getdefaultlocale()
+ except locale.Error, err:
+ print >>sys.stderr, "WARNING:", err
+ lcAll = []
+
+ if len(lcAll) == 2:
+ default_encoding = lcAll[1]
+ else:
+ try:
+ default_encoding = locale.getpreferredencoding()
+ except locale.Error, err:
+ print >>sys.stderr, "WARNING:", err
+ default_encoding = sys.getdefaultencoding()
+else:
+ default_encoding = sys.getdefaultencoding()
+
import logging
logger = logging.getLogger('torrent-mcextfs')
log_err_handler = logging.StreamHandler(sys.stderr)
)
sys.exit(1)
-
locale.setlocale(locale.LC_ALL, '')
-charset = locale.getpreferredencoding()
def mctorrent_list():
if 'path.utf-8' in file:
if name_utf8:
path = '/'.join([name_utf8] + file['path.utf-8'])
- if charset and (charset != 'utf-8'):
- path = path.decode('utf-8', 'replace').encode(charset, 'replace')
+ if default_encoding != 'utf-8':
+ path = path.decode('utf-8', 'replace').encode(default_encoding, 'replace')
else:
_name_utf8 = name
if encoding and (encoding != 'utf-8'):
_name_utf8 = _name_utf8.decode(encoding, 'replace').encode('utf-8', 'replace')
path = '/'.join([_name_utf8] + file['path.utf-8'])
- if charset and (charset != 'utf-8'):
- path = path.decode('utf-8', 'replace').encode(charset, 'replace')
+ if default_encoding != 'utf-8':
+ path = path.decode('utf-8', 'replace').encode(default_encoding, 'replace')
else:
if name_utf8:
path = file['path']
if encoding and (encoding != 'utf-8'):
path = path.decode(encoding, 'replace').encode('utf-8', 'replace')
path = '/'.join([name_utf8] + path)
- if charset and (charset != 'utf-8'):
- path = path.decode('utf-8', 'replace').encode(charset, 'replace')
+ if default_encoding != 'utf-8':
+ path = path.decode('utf-8', 'replace').encode(default_encoding, 'replace')
else:
path = '/'.join([name] + file['path'])
- if charset and encoding and (charset != encoding):
- path = path.decode(encoding, 'replace').encode(charset, 'replace')
+ if encoding and (default_encoding != encoding):
+ path = path.decode(encoding, 'replace').encode(default_encoding, 'replace')
length = file['length']
paths.append((path, length))
else: # One-file torrent
torrent_error('Unknown length')
length = info['length']
if name_utf8:
- if charset and (charset != 'utf-8'):
- name = name_utf8.decode('utf-8', 'replace').encode(charset, 'replace')
- elif charset and encoding and (charset != encoding):
- name = name.decode(encoding, 'replace').encode(charset, 'replace')
+ if default_encoding != 'utf-8':
+ name = name_utf8.decode('utf-8', 'replace').encode(default_encoding, 'replace')
+ elif encoding and (default_encoding != encoding):
+ name = name.decode(encoding, 'replace').encode(default_encoding, 'replace')
paths = [(name, length)]
meta = []
'created by', 'creation date', 'encoding', \
'nodes', 'publisher', 'publisher-url':
if name == 'comment' and 'comment.utf-8' in torrent:
- data = torrent['comment.utf-8'].decode('utf-8').encode(charset, 'replace')
+ data = torrent['comment.utf-8'].decode('utf-8').encode(default_encoding, 'replace')
meta.append(('.META/' + name, len(data)))
elif name in torrent:
if name == 'announce-list':
'created by', 'creation date', 'encoding', \
'nodes', 'publisher', 'publisher-url':
if name == 'comment' and 'comment.utf-8' in torrent:
- data = torrent['comment.utf-8'].decode('utf-8').encode(charset, 'replace')
+ data = torrent['comment.utf-8'].decode('utf-8').encode(default_encoding, 'replace')
meta.append(('.META/' + name, len(data)))
elif torrent_filename == '.META/' + name:
if name in torrent: