mirror of
https://github.com/beetbox/beets.git
synced 2025-12-30 20:42:37 +01:00
Attempted fix for #2515 (convert on Windows)
On Python 3, this tries to pass through the Unicode filename representation for paths to the Windows API.
This commit is contained in:
parent
45bed808d3
commit
c7801d4cc0
1 changed files with 14 additions and 3 deletions
|
|
@ -24,6 +24,7 @@ import tempfile
|
|||
import shlex
|
||||
import six
|
||||
from string import Template
|
||||
import platform
|
||||
|
||||
from beets import ui, util, plugins, config
|
||||
from beets.plugins import BeetsPlugin
|
||||
|
|
@ -183,12 +184,22 @@ class ConvertPlugin(BeetsPlugin):
|
|||
if not quiet and not pretend:
|
||||
self._log.info(u'Encoding {0}', util.displayable_path(source))
|
||||
|
||||
# Substitute $source and $dest in the argument list.
|
||||
# On Python 3, we need to construct the command to invoke as a
|
||||
# Unicode string. On Unix, this is a little unfortunate---the OS is
|
||||
# expecting bytes---so we use surrogate escaping and decode with the
|
||||
# argument encoding, which is the same encoding that will then be
|
||||
# *reversed* to recover the same bytes before invoking the OS. On
|
||||
# Windows, we want to preserve the Unicode filename "as is."
|
||||
if not six.PY2:
|
||||
command = command.decode(util.arg_encoding(), 'surrogateescape')
|
||||
source = source.decode(util.arg_encoding(), 'surrogateescape')
|
||||
dest = dest.decode(util.arg_encoding(), 'surrogateescape')
|
||||
if platform.system() == 'Windows':
|
||||
source = source.decode(util._fsencoding())
|
||||
dest = dest.decode(util._fsencoding())
|
||||
else:
|
||||
source = source.decode(util.arg_encoding(), 'surrogateescape')
|
||||
dest = dest.decode(util.arg_encoding(), 'surrogateescape')
|
||||
|
||||
# Substitute $source and $dest in the argument list.
|
||||
args = shlex.split(command)
|
||||
encode_cmd = []
|
||||
for i, arg in enumerate(args):
|
||||
|
|
|
|||
Loading…
Reference in a new issue