X-Git-Url: https://git.phdru.name/?p=extfs.d.git;a=blobdiff_plain;f=obexftp;h=91ec121f190a5644aacb1c65001fd20c34b36bbe;hp=76e35a13dd6828cf96cb48958aa326b9fc8b6529;hb=8d10b98d9f945640120e87e0eeab56a40e66207d;hpb=d4f18638c91d6601adf2f6e1392b0af8781cbf93 diff --git a/obexftp b/obexftp index 76e35a1..91ec121 100755 --- a/obexftp +++ b/obexftp @@ -8,10 +8,10 @@ undocumented "run"; anyway there are no runnable files in cell phones. The script is written in Python because I I need to parse XML directory listings from obexftp, and Python is the best of all languages suited for the task ;). -The script requires Midnight Commander 3.1+ (http://www.ibiblio.org/mc/), -Python 2.3+ (http://www.python.org/), -OpenOBEX 1.0.1+ (http://openobex.sourceforge.net/) and -ObexFTP 0.10.4+ (http://triq.net/obexftp). +The script requires Midnight Commander 3.1+ +(http://www.midnight-commander.org/), Python 2.3+ (http://www.python.org/), +OpenOBEX 1.0.1+ (http://dev.zuckschwerdt.org/openobex/) and ObexFTP 0.10.4+ +(http://triq.net/obexftp). Edit the script, and correct the the full path to the obexftp binary (see obexftp_prog below). For mc 4.7+ put the script in $HOME/.mc/extfs.d. @@ -64,9 +64,9 @@ named in $TMP environment variable. """ -__version__ = "1.3.1" +__version__ = "1.4.0" __author__ = "Oleg Broytman " -__copyright__ = "Copyright (C) 2004-2012 PhiloSoft Design" +__copyright__ = "Copyright (C) 2004-2013 PhiloSoft Design" __license__ = "GPL" @@ -76,9 +76,34 @@ obexftp_prog = "/usr/bin/obexftp" 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') @@ -93,8 +118,8 @@ ObexFTP Virtual FileSystem for Midnight Commander version %s Author: %s %s -This is not a program. Put the script in /usr/[local/][lib|share]/mc/extfs. -For more information read the source!""", +This is not a program. Put the script in $HOME/.mc/extfs.d or +/usr/[local/][lib|share]/mc/extfs. For more information read the source!""", __version__, __author__, __copyright__ ) sys.exit(1) @@ -123,7 +148,6 @@ logger.removeHandler(log_err_handler) logger.addHandler(logging.FileHandler(logfile_name)) locale.setlocale(locale.LC_ALL, '') -charset = locale.getpreferredencoding() # Parse ObexFTP XML directory listings @@ -238,7 +262,7 @@ def recursive_list(directory='/'): 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