Auto merge of #2566 - micbou:python3, r=puremourning
[READY] Prefer Python 3 over Python 2 When both versions are available, we should use Python 3 over Python 2 for the following reasons: - faster startup: <table> <tr> <th rowspan="2">Platform</th> <th colspan="2">First run (ms)</th> <th colspan="2">Subsequent runs (ms)</th> </tr> <tr> <td>Python 2</td> <td>Python 3</td> <td>Python 2</td> <td>Python 3</td> </tr> <tr> <td>Ubuntu 16.04 64-bit</td> <td>197</td> <td>110</td> <td>117</td> <td>84</td> </tr> <tr> <td>macOS 10.12</td> <td>322</td> <td>186</td> <td>210</td> <td>124</td> </tr> <tr> <td>Windows 10 64-bit</td> <td>601</td> <td>295</td> <td>251</td> <td>144</td> </tr> </table> *Results obtained by running the `prof.py` script from [this branch](https://github.com/micbou/YouCompleteMe/tree/profiling-startup). The difference between first run and subsequent runs is Python bytecode generation (`*.pyc` files).* These differences are due to `python-future` monkey-patching a lot of stuff on Python 2 but not on Python 3; - better Windows support. For instance, [the `tempfile` module returns temporary paths in all lowercase on Python 2](https://bugs.python.org/issue14255) (we use it to create our logfiles). This is fixed on Python 3. - [Python 2 support will be dropped in 2020](https://docs.python.org/devguide/index.html#branchstatus). <!-- Reviewable:start --> --- This change is [<img src="https://reviewable.io/review_button.svg" height="34" align="absmiddle" alt="Reviewable"/>](https://reviewable.io/reviews/valloric/youcompleteme/2566) <!-- Reviewable:end -->
This commit is contained in:
commit
cb2f6d7953
@ -28,26 +28,29 @@ let s:cursor_moved = 0
|
|||||||
let s:previous_allowed_buffer_number = 0
|
let s:previous_allowed_buffer_number = 0
|
||||||
|
|
||||||
|
|
||||||
function! s:UsingPython2()
|
" When both versions are available, we prefer Python 3 over Python 2:
|
||||||
" I'm willing to bet quite a bit that sooner or later, somebody will ask us to
|
" - faster startup (no monkey-patching from python-future);
|
||||||
" make it configurable which version of Python we use.
|
" - better Windows support (e.g. temporary paths are not returned in all
|
||||||
if has('python')
|
" lowercase);
|
||||||
|
" - Python 2 support will eventually be dropped.
|
||||||
|
function! s:UsingPython3()
|
||||||
|
if has('python3')
|
||||||
return 1
|
return 1
|
||||||
endif
|
endif
|
||||||
return 0
|
return 0
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
|
||||||
let s:using_python2 = s:UsingPython2()
|
let s:using_python3 = s:UsingPython3()
|
||||||
let s:python_until_eof = s:using_python2 ? "python << EOF" : "python3 << EOF"
|
let s:python_until_eof = s:using_python3 ? "python3 << EOF" : "python << EOF"
|
||||||
let s:python_command = s:using_python2 ? "py " : "py3 "
|
let s:python_command = s:using_python3 ? "py3 " : "py "
|
||||||
|
|
||||||
|
|
||||||
function! s:Pyeval( eval_string )
|
function! s:Pyeval( eval_string )
|
||||||
if s:using_python2
|
if s:using_python3
|
||||||
return pyeval( a:eval_string )
|
return py3eval( a:eval_string )
|
||||||
endif
|
endif
|
||||||
return py3eval( a:eval_string )
|
return pyeval( a:eval_string )
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user