From: Vedant Kumar Date: Sat, 10 Dec 2016 00:54:13 +0000 (+0000) Subject: [clang-format] Another attempt at python 3 compatibility X-Git-Tag: llvmorg-4.0.0-rc1~2451 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=0972da7870d7bf9a3ac1d47246db5c62f28e671a;p=platform%2Fupstream%2Fllvm.git [clang-format] Another attempt at python 3 compatibility The entries in vim.current.buffer appear to be decoded strings, which means that python3 won't allow invoking 'decode' on them. Keep the old behavior when running under python2, but skip the error-inducing decode step with python3.. llvm-svn: 289308 --- diff --git a/clang/tools/clang-format/clang-format.py b/clang/tools/clang-format/clang-format.py index aded301..ae8a6eb 100644 --- a/clang/tools/clang-format/clang-format.py +++ b/clang/tools/clang-format/clang-format.py @@ -29,6 +29,7 @@ from __future__ import print_function import difflib import json +import platform import subprocess import sys import vim @@ -48,10 +49,15 @@ fallback_style = None if vim.eval('exists("g:clang_format_fallback_style")') == "1": fallback_style = vim.eval('g:clang_format_fallback_style') +def get_buffer(encoding): + if platform.python_version_tuple()[0] == '3': + return vim.current.buffer + return [ line.decode(encoding) for line in vim.current.buffer ] + def main(): # Get the current text. encoding = vim.eval("&encoding") - buf = [ line.decode(encoding) for line in vim.current.buffer ] + buf = get_buffer(encoding) text = '\n'.join(buf) # Determine range to format.