diff options
| author | Sergey M․ <dstftw@gmail.com> | 2014-09-30 22:27:53 +0700 | 
|---|---|---|
| committer | Sergey M․ <dstftw@gmail.com> | 2014-09-30 22:27:53 +0700 | 
| commit | 4644ac5527e48a1a8c48dc790621c73913e6dbf8 (patch) | |
| tree | 3ff5c762d57d8d07755959b442457821d13fdc90 /youtube_dl/utils.py | |
| parent | e497a7f2ca46d485c2839969abc598faa16c49dc (diff) | |
[core] Decode environment variables with filesystem encoding (Fixes #3854, Fixes #3217, Fixes #2918)
Introduces compat versions of os.getenv and os.path.expanduser
Diffstat (limited to 'youtube_dl/utils.py')
| -rw-r--r-- | youtube_dl/utils.py | 53 | 
1 files changed, 49 insertions, 4 deletions
| diff --git a/youtube_dl/utils.py b/youtube_dl/utils.py index f05747097..afe32ae05 100644 --- a/youtube_dl/utils.py +++ b/youtube_dl/utils.py @@ -203,6 +203,48 @@ def compat_ord(c):      if type(c) is int: return c      else: return ord(c) + +# Environment variables should be decoded with filesystem encoding +# otherwise this results in issues like #3854 #2918 #3217 +if sys.version_info >= (3, 0): +    compat_getenv = os.getenv +    compat_expanduser = os.path.expanduser +else: +    def compat_getenv(key, default=None): +        env = os.getenv(key, default) +        if env: +            env = env.decode(get_filesystem_encoding()) +        return env + +    def compat_expanduser(path): +        """Expand ~ and ~user constructs. + +        If user or $HOME is unknown, do nothing.""" +        if path[:1] != '~': +            return path +        i, n = 1, len(path) +        while i < n and path[i] not in '/\\': +            i += 1 + +        if 'HOME' in os.environ: +            userhome = compat_getenv('HOME') +        elif 'USERPROFILE' in os.environ: +            userhome = compat_getenv('USERPROFILE') +        elif not 'HOMEPATH' in os.environ: +            return path +        else: +            try: +                drive = compat_getenv('HOMEDRIVE') +            except KeyError: +                drive = '' +            userhome = os.path.join(drive, compat_getenv('HOMEPATH')) + +        if i != 1:  # ~user +            userhome = os.path.join(os.path.dirname(userhome), path[1:i]) + +        return userhome + path[i:] + +  # This is not clearly defined otherwise  compiled_regex_type = type(re.compile('')) @@ -1204,11 +1246,14 @@ class locked_file(object):          return self.f.read(*args) +def get_filesystem_encoding(): +    encoding = sys.getfilesystemencoding() +    return encoding if encoding is not None else 'utf-8' + +  def shell_quote(args):      quoted_args = [] -    encoding = sys.getfilesystemencoding() -    if encoding is None: -        encoding = 'utf-8' +    encoding = get_filesystem_encoding()      for a in args:          if isinstance(a, bytes):              # We may get a filename encoded with 'encodeFilename' @@ -1258,7 +1303,7 @@ def format_bytes(bytes):  def get_term_width(): -    columns = os.environ.get('COLUMNS', None) +    columns = compat_getenv('COLUMNS', None)      if columns:          return int(columns) | 
