##// END OF EJS Templates
Merge pull request #10865 from hugovk/rm-python2...
Thomas Kluyver -
r24018:5b2b7dd0 merge
parent child Browse files
Show More
@@ -0,0 +1,19 b''
1 # Top-most EditorConfig file
2 root = true
3
4 [*]
5 # Unix-style newlines with a newline ending every file
6 end_of_line = lf
7 insert_final_newline = true
8 charset = utf-8
9
10 # Four-space indentation
11 indent_size = 4
12 indent_style = space
13
14 trim_trailing_whitespace = false
15
16 [*.yml]
17 # Two-space indentation
18 indent_size = 2
19 indent_style = space
@@ -21,5 +21,6 b' __pycache__'
21 .DS_Store
21 .DS_Store
22 \#*#
22 \#*#
23 .#*
23 .#*
24 .cache
24 .coverage
25 .coverage
25 *.swp
26 *.swp
@@ -218,8 +218,8 b' class ScriptMagics(Magics):'
218 print("Error while terminating subprocess (pid=%i): %s" \
218 print("Error while terminating subprocess (pid=%i): %s" \
219 % (p.pid, e))
219 % (p.pid, e))
220 return
220 return
221 out = py3compat.bytes_to_str(out)
221 out = py3compat.decode(out)
222 err = py3compat.bytes_to_str(err)
222 err = py3compat.decode(err)
223 if args.out:
223 if args.out:
224 self.shell.user_ns[args.out] = out
224 self.shell.user_ns[args.out] = out
225 else:
225 else:
@@ -10,7 +10,6 b' from traitlets import Unicode'
10
10
11 from IPython.core.application import BaseIPythonApplication
11 from IPython.core.application import BaseIPythonApplication
12 from IPython.testing import decorators as dec
12 from IPython.testing import decorators as dec
13 from IPython.utils import py3compat
14 from IPython.utils.tempdir import TemporaryDirectory
13 from IPython.utils.tempdir import TemporaryDirectory
15
14
16
15
@@ -22,7 +22,6 b' import nose.tools as nt'
22
22
23 # Our own imports
23 # Our own imports
24 from IPython.core import compilerop
24 from IPython.core import compilerop
25 from IPython.utils import py3compat
26
25
27 #-----------------------------------------------------------------------------
26 #-----------------------------------------------------------------------------
28 # Test functions
27 # Test functions
@@ -17,7 +17,6 b' from os.path import join'
17 import nose.tools as nt
17 import nose.tools as nt
18
18
19 from IPython.core.completerlib import magic_run_completer, module_completion
19 from IPython.core.completerlib import magic_run_completer, module_completion
20 from IPython.utils import py3compat
21 from IPython.utils.tempdir import TemporaryDirectory
20 from IPython.utils.tempdir import TemporaryDirectory
22 from IPython.testing.decorators import onlyif_unicode_paths
21 from IPython.testing.decorators import onlyif_unicode_paths
23
22
@@ -19,7 +19,6 b' import nose.tools as nt'
19 from traitlets.config.loader import Config
19 from traitlets.config.loader import Config
20 from IPython.utils.tempdir import TemporaryDirectory
20 from IPython.utils.tempdir import TemporaryDirectory
21 from IPython.core.history import HistoryManager, extract_hist_ranges
21 from IPython.core.history import HistoryManager, extract_hist_ranges
22 from IPython.utils import py3compat
23
22
24 def setUp():
23 def setUp():
25 nt.assert_equal(sys.getdefaultencoding(), "utf-8")
24 nt.assert_equal(sys.getdefaultencoding(), "utf-8")
@@ -17,7 +17,6 b' import sys'
17 import tempfile
17 import tempfile
18 import unittest
18 import unittest
19 from unittest import mock
19 from unittest import mock
20 from io import StringIO
21
20
22 from os.path import join
21 from os.path import join
23
22
@@ -30,7 +29,6 b' from IPython.testing.decorators import ('
30 )
29 )
31 from IPython.testing import tools as tt
30 from IPython.testing import tools as tt
32 from IPython.utils.process import find_cmd
31 from IPython.utils.process import find_cmd
33 from IPython.utils import py3compat
34
32
35 #-----------------------------------------------------------------------------
33 #-----------------------------------------------------------------------------
36 # Globals
34 # Globals
@@ -19,10 +19,8 b' from IPython.core.magic import (Magics, magics_class, line_magic,'
19 register_line_cell_magic)
19 register_line_cell_magic)
20 from decorator import decorator
20 from decorator import decorator
21 from IPython import get_ipython
21 from IPython import get_ipython
22 from IPython.testing.decorators import skipif
23 from IPython.testing.tools import AssertPrints, AssertNotPrints
22 from IPython.testing.tools import AssertPrints, AssertNotPrints
24 from IPython.utils.path import compress_user
23 from IPython.utils.path import compress_user
25 from IPython.utils import py3compat
26
24
27
25
28 #-----------------------------------------------------------------------------
26 #-----------------------------------------------------------------------------
@@ -40,14 +38,14 b' ip = get_ipython()'
40 # defined, if any code is inserted above, the following line will need to be
38 # defined, if any code is inserted above, the following line will need to be
41 # updated. Do NOT insert any whitespace between the next line and the function
39 # updated. Do NOT insert any whitespace between the next line and the function
42 # definition below.
40 # definition below.
43 THIS_LINE_NUMBER = 43 # Put here the actual number of this line
41 THIS_LINE_NUMBER = 41 # Put here the actual number of this line
44
42
45 from unittest import TestCase
43 from unittest import TestCase
46
44
47 class Test(TestCase):
45 class Test(TestCase):
48
46
49 def test_find_source_lines(self):
47 def test_find_source_lines(self):
50 self.assertEqual(oinspect.find_source_lines(Test.test_find_source_lines),
48 self.assertEqual(oinspect.find_source_lines(Test.test_find_source_lines),
51 THIS_LINE_NUMBER+6)
49 THIS_LINE_NUMBER+6)
52
50
53
51
@@ -3,7 +3,6 b' import nose.tools as nt'
3
3
4 from IPython.core.splitinput import split_user_input, LineInfo
4 from IPython.core.splitinput import split_user_input, LineInfo
5 from IPython.testing import tools as tt
5 from IPython.testing import tools as tt
6 from IPython.utils import py3compat
7
6
8 tests = [
7 tests = [
9 ('x=1', ('', '', 'x', '=1')),
8 ('x=1', ('', '', 'x', '=1')),
@@ -1136,35 +1136,32 b' class VerboseTB(TBTools):'
1136 colorsnormal = colors.Normal # used a lot
1136 colorsnormal = colors.Normal # used a lot
1137 head = '%s%s%s' % (colors.topline, '-' * min(75, get_terminal_size()[0]), colorsnormal)
1137 head = '%s%s%s' % (colors.topline, '-' * min(75, get_terminal_size()[0]), colorsnormal)
1138 structured_traceback_parts = [head]
1138 structured_traceback_parts = [head]
1139 if py3compat.PY3:
1139 chained_exceptions_tb_offset = 0
1140 chained_exceptions_tb_offset = 0
1140 lines_of_context = 3
1141 lines_of_context = 3
1141 formatted_exceptions = formatted_exception
1142 formatted_exceptions = formatted_exception
1142 exception = self.get_parts_of_chained_exception(evalue)
1143 if exception:
1144 formatted_exceptions += self.prepare_chained_exception_message(evalue.__cause__)
1145 etype, evalue, etb = exception
1146 else:
1147 evalue = None
1148 chained_exc_ids = set()
1149 while evalue:
1150 formatted_exceptions += self.format_exception_as_a_whole(etype, evalue, etb, lines_of_context,
1151 chained_exceptions_tb_offset)
1143 exception = self.get_parts_of_chained_exception(evalue)
1152 exception = self.get_parts_of_chained_exception(evalue)
1144 if exception:
1153
1154 if exception and not id(exception[1]) in chained_exc_ids:
1155 chained_exc_ids.add(id(exception[1])) # trace exception to avoid infinite 'cause' loop
1145 formatted_exceptions += self.prepare_chained_exception_message(evalue.__cause__)
1156 formatted_exceptions += self.prepare_chained_exception_message(evalue.__cause__)
1146 etype, evalue, etb = exception
1157 etype, evalue, etb = exception
1147 else:
1158 else:
1148 evalue = None
1159 evalue = None
1149 chained_exc_ids = set()
1150 while evalue:
1151 formatted_exceptions += self.format_exception_as_a_whole(etype, evalue, etb, lines_of_context,
1152 chained_exceptions_tb_offset)
1153 exception = self.get_parts_of_chained_exception(evalue)
1154
1155 if exception and not id(exception[1]) in chained_exc_ids:
1156 chained_exc_ids.add(id(exception[1])) # trace exception to avoid infinite 'cause' loop
1157 formatted_exceptions += self.prepare_chained_exception_message(evalue.__cause__)
1158 etype, evalue, etb = exception
1159 else:
1160 evalue = None
1161
1160
1162 # we want to see exceptions in a reversed order:
1161 # we want to see exceptions in a reversed order:
1163 # the first exception should be on top
1162 # the first exception should be on top
1164 for formatted_exception in reversed(formatted_exceptions):
1163 for formatted_exception in reversed(formatted_exceptions):
1165 structured_traceback_parts += formatted_exception
1164 structured_traceback_parts += formatted_exception
1166 else:
1167 structured_traceback_parts += formatted_exception[0]
1168
1165
1169 return structured_traceback_parts
1166 return structured_traceback_parts
1170
1167
@@ -116,7 +116,6 b' import traceback'
116 import types
116 import types
117 import weakref
117 import weakref
118 from importlib import import_module
118 from importlib import import_module
119 from IPython.utils.py3compat import PY3
120 from imp import reload
119 from imp import reload
121
120
122 from IPython.utils import openpy
121 from IPython.utils import openpy
@@ -11,7 +11,7 b' import random'
11
11
12 # Our own
12 # Our own
13 from IPython.core.error import UsageError
13 from IPython.core.error import UsageError
14 from IPython.utils.py3compat import cast_bytes, str_to_bytes
14 from IPython.utils.py3compat import encode
15
15
16 #-----------------------------------------------------------------------------
16 #-----------------------------------------------------------------------------
17 # Globals
17 # Globals
@@ -65,7 +65,7 b" def passwd(passphrase=None, algorithm='sha1'):"
65
65
66 h = hashlib.new(algorithm)
66 h = hashlib.new(algorithm)
67 salt = ('%0' + str(salt_len) + 'x') % random.getrandbits(4 * salt_len)
67 salt = ('%0' + str(salt_len) + 'x') % random.getrandbits(4 * salt_len)
68 h.update(cast_bytes(passphrase, 'utf-8') + str_to_bytes(salt, 'ascii'))
68 h.update(encode(passphrase, 'utf-8') + encode(salt, 'ascii'))
69
69
70 return ':'.join((algorithm, salt, h.hexdigest()))
70 return ':'.join((algorithm, salt, h.hexdigest()))
71
71
@@ -109,6 +109,6 b' def passwd_check(hashed_passphrase, passphrase):'
109 if len(pw_digest) == 0:
109 if len(pw_digest) == 0:
110 return False
110 return False
111
111
112 h.update(cast_bytes(passphrase, 'utf-8') + cast_bytes(salt, 'ascii'))
112 h.update(encode(passphrase, 'utf-8') + encode(salt, 'ascii'))
113
113
114 return h.hexdigest() == pw_digest
114 return h.hexdigest() == pw_digest
@@ -7,7 +7,7 b' from warnings import warn'
7
7
8 from IPython.core.interactiveshell import InteractiveShell, InteractiveShellABC
8 from IPython.core.interactiveshell import InteractiveShell, InteractiveShellABC
9 from IPython.utils import io
9 from IPython.utils import io
10 from IPython.utils.py3compat import input, cast_unicode_py2
10 from IPython.utils.py3compat import input
11 from IPython.utils.terminal import toggle_set_term_title, set_term_title
11 from IPython.utils.terminal import toggle_set_term_title, set_term_title
12 from IPython.utils.process import abbrev_cwd
12 from IPython.utils.process import abbrev_cwd
13 from traitlets import (
13 from traitlets import (
@@ -233,7 +233,7 b' class TerminalInteractiveShell(InteractiveShell):'
233 prompt_text = "".join(x[1] for x in self.prompts.in_prompt_tokens())
233 prompt_text = "".join(x[1] for x in self.prompts.in_prompt_tokens())
234 prompt_continuation = "".join(x[1] for x in self.prompts.continuation_prompt_tokens())
234 prompt_continuation = "".join(x[1] for x in self.prompts.continuation_prompt_tokens())
235 while isp.push_accepts_more():
235 while isp.push_accepts_more():
236 line = cast_unicode_py2(input(prompt_text))
236 line = input(prompt_text)
237 isp.push(line)
237 isp.push(line)
238 prompt_text = prompt_continuation
238 prompt_text = prompt_continuation
239 return isp.source_reset()
239 return isp.source_reset()
@@ -31,8 +31,9 b" we've copied verbatim from numpy."
31 # Copyright (c) IPython Development Team.
31 # Copyright (c) IPython Development Team.
32 # Distributed under the terms of the Modified BSD License.
32 # Distributed under the terms of the Modified BSD License.
33
33
34 import sys
35 import os
34 import os
35 import shutil
36 import sys
36 import tempfile
37 import tempfile
37 import unittest
38 import unittest
38 import warnings
39 import warnings
@@ -48,9 +49,6 b' from .ipunittest import ipdoctest, ipdocstring'
48 # numpy.testing.decorators, we expose all of it here.
49 # numpy.testing.decorators, we expose all of it here.
49 from IPython.external.decorators import *
50 from IPython.external.decorators import *
50
51
51 # For onlyif_cmd_exists decorator
52 from IPython.utils.py3compat import which
53
54 #-----------------------------------------------------------------------------
52 #-----------------------------------------------------------------------------
55 # Classes and functions
53 # Classes and functions
56 #-----------------------------------------------------------------------------
54 #-----------------------------------------------------------------------------
@@ -360,7 +358,7 b' def onlyif_cmds_exist(*commands):'
360 Decorator to skip test when at least one of `commands` is not found.
358 Decorator to skip test when at least one of `commands` is not found.
361 """
359 """
362 for cmd in commands:
360 for cmd in commands:
363 if not which(cmd):
361 if not shutil.which(cmd):
364 return skip("This test runs only if command '{0}' "
362 return skip("This test runs only if command '{0}' "
365 "is installed".format(cmd))
363 "is installed".format(cmd))
366 return null_deco
364 return null_deco
@@ -372,7 +370,7 b' def onlyif_any_cmd_exists(*commands):'
372 warnings.warn("The function `onlyif_any_cmd_exists` is deprecated since IPython 4.0",
370 warnings.warn("The function `onlyif_any_cmd_exists` is deprecated since IPython 4.0",
373 DeprecationWarning, stacklevel=2)
371 DeprecationWarning, stacklevel=2)
374 for cmd in commands:
372 for cmd in commands:
375 if which(cmd):
373 if shutil.which(cmd):
376 return null_deco
374 return null_deco
377 return skip("This test runs only if one of the commands {0} "
375 return skip("This test runs only if one of the commands {0} "
378 "is installed".format(commands))
376 "is installed".format(commands))
@@ -11,13 +11,13 b' done.'
11
11
12 import builtins as builtin_mod
12 import builtins as builtin_mod
13 import sys
13 import sys
14 import types
14 import warnings
15 import warnings
15
16
16 from . import tools
17 from . import tools
17
18
18 from IPython.core import page
19 from IPython.core import page
19 from IPython.utils import io
20 from IPython.utils import io
20 from IPython.utils import py3compat
21 from IPython.terminal.interactiveshell import TerminalInteractiveShell
21 from IPython.terminal.interactiveshell import TerminalInteractiveShell
22
22
23
23
@@ -104,9 +104,9 b' def start_ipython():'
104 # Modify the IPython system call with one that uses getoutput, so that we
104 # Modify the IPython system call with one that uses getoutput, so that we
105 # can capture subcommands and print them to Python's stdout, otherwise the
105 # can capture subcommands and print them to Python's stdout, otherwise the
106 # doctest machinery would miss them.
106 # doctest machinery would miss them.
107 shell.system = py3compat.MethodType(xsys, shell)
107 shell.system = types.MethodType(xsys, shell)
108
108
109 shell._showtraceback = py3compat.MethodType(_showtraceback, shell)
109 shell._showtraceback = types.MethodType(_showtraceback, shell)
110
110
111 # IPython is ready, now clean up some global state...
111 # IPython is ready, now clean up some global state...
112
112
@@ -34,7 +34,7 b' from nose.plugins import Plugin'
34 from nose.util import safe_str
34 from nose.util import safe_str
35
35
36 from IPython import version_info
36 from IPython import version_info
37 from IPython.utils.py3compat import bytes_to_str
37 from IPython.utils.py3compat import decode
38 from IPython.utils.importstring import import_item
38 from IPython.utils.importstring import import_item
39 from IPython.testing.plugin.ipdoctest import IPythonDoctest
39 from IPython.testing.plugin.ipdoctest import IPythonDoctest
40 from IPython.external.decorators import KnownFailure, knownfailureif
40 from IPython.external.decorators import KnownFailure, knownfailureif
@@ -299,8 +299,8 b' class StreamCapturer(Thread):'
299 with self.buffer_lock:
299 with self.buffer_lock:
300 self.buffer.write(chunk)
300 self.buffer.write(chunk)
301 if self.echo:
301 if self.echo:
302 sys.stdout.write(bytes_to_str(chunk))
302 sys.stdout.write(decode(chunk))
303
303
304 os.close(self.readfd)
304 os.close(self.readfd)
305 os.close(self.writefd)
305 os.close(self.writefd)
306
306
@@ -24,7 +24,7 b' from .iptest import ('
24 have, test_group_names as py_test_group_names, test_sections, StreamCapturer,
24 have, test_group_names as py_test_group_names, test_sections, StreamCapturer,
25 )
25 )
26 from IPython.utils.path import compress_user
26 from IPython.utils.path import compress_user
27 from IPython.utils.py3compat import bytes_to_str
27 from IPython.utils.py3compat import decode
28 from IPython.utils.sysinfo import get_sys_info
28 from IPython.utils.sysinfo import get_sys_info
29 from IPython.utils.tempdir import TemporaryDirectory
29 from IPython.utils.tempdir import TemporaryDirectory
30
30
@@ -371,7 +371,7 b' def run_iptestall(options):'
371 print(justify('Test group: ' + controller.section, res_string))
371 print(justify('Test group: ' + controller.section, res_string))
372 if res:
372 if res:
373 controller.print_extra_info()
373 controller.print_extra_info()
374 print(bytes_to_str(controller.stdout))
374 print(decode(controller.stdout))
375 failed.append(controller)
375 failed.append(controller)
376 if res == -signal.SIGINT:
376 if res == -signal.SIGINT:
377 print("Interrupted")
377 print("Interrupted")
@@ -33,7 +33,6 b' from IPython.utils.process import get_output_error_code'
33 from IPython.utils.text import list_strings
33 from IPython.utils.text import list_strings
34 from IPython.utils.io import temp_pyfile, Tee
34 from IPython.utils.io import temp_pyfile, Tee
35 from IPython.utils import py3compat
35 from IPython.utils import py3compat
36 from IPython.utils.encoding import DEFAULT_ENCODING
37
36
38 from . import decorators as dec
37 from . import decorators as dec
39 from . import skipdoctest
38 from . import skipdoctest
@@ -210,8 +209,8 b' def ipexec(fname, options=None, commands=()):'
210 if not isinstance(v, str):
209 if not isinstance(v, str):
211 print(k, v)
210 print(k, v)
212 p = Popen(full_cmd, stdout=PIPE, stderr=PIPE, stdin=PIPE, env=env)
211 p = Popen(full_cmd, stdout=PIPE, stderr=PIPE, stdin=PIPE, env=env)
213 out, err = p.communicate(input=py3compat.str_to_bytes('\n'.join(commands)) or None)
212 out, err = p.communicate(input=py3compat.encode('\n'.join(commands)) or None)
214 out, err = py3compat.bytes_to_str(out), py3compat.bytes_to_str(err)
213 out, err = py3compat.decode(out), py3compat.decode(err)
215 # `import readline` causes 'ESC[?1034h' to be output sometimes,
214 # `import readline` causes 'ESC[?1034h' to be output sometimes,
216 # so strip that out before doing comparisons
215 # so strip that out before doing comparisons
217 if out:
216 if out:
@@ -28,7 +28,7 b' def _find_cmd(cmd):'
28 for path in paths:
28 for path in paths:
29 filename = os.path.join(path, cmd)
29 filename = os.path.join(path, cmd)
30 if System.IO.File.Exists(filename):
30 if System.IO.File.Exists(filename):
31 return py3compat.bytes_to_str(filename)
31 return py3compat.decode(filename)
32 raise OSError("command %r not found" % cmd)
32 raise OSError("command %r not found" % cmd)
33
33
34 def system(cmd):
34 def system(cmd):
@@ -130,7 +130,7 b' def getoutput(cmd):'
130 out = process_handler(cmd, lambda p: p.communicate()[0], subprocess.STDOUT)
130 out = process_handler(cmd, lambda p: p.communicate()[0], subprocess.STDOUT)
131 if out is None:
131 if out is None:
132 return ''
132 return ''
133 return py3compat.bytes_to_str(out)
133 return py3compat.decode(out)
134
134
135
135
136 def getoutputerror(cmd):
136 def getoutputerror(cmd):
@@ -172,7 +172,7 b' def get_output_error_code(cmd):'
172 if out_err is None:
172 if out_err is None:
173 return '', '', p.returncode
173 return '', '', p.returncode
174 out, err = out_err
174 out, err = out_err
175 return py3compat.bytes_to_str(out), py3compat.bytes_to_str(err), p.returncode
175 return py3compat.decode(out), py3compat.decode(err), p.returncode
176
176
177 def arg_split(s, posix=False, strict=True):
177 def arg_split(s, posix=False, strict=True):
178 """Split a command line's arguments in a shell-like manner.
178 """Split a command line's arguments in a shell-like manner.
@@ -36,7 +36,7 b' def _find_cmd(cmd):'
36
36
37 path = sp.Popen(['/usr/bin/env', 'which', cmd],
37 path = sp.Popen(['/usr/bin/env', 'which', cmd],
38 stdout=sp.PIPE, stderr=sp.PIPE).communicate()[0]
38 stdout=sp.PIPE, stderr=sp.PIPE).communicate()[0]
39 return py3compat.bytes_to_str(path)
39 return py3compat.decode(path)
40
40
41
41
42 class ProcessHandler(object):
42 class ProcessHandler(object):
@@ -152,7 +152,7 b' def getoutput(cmd):'
152
152
153 if out is None:
153 if out is None:
154 out = b''
154 out = b''
155 return py3compat.bytes_to_str(out)
155 return py3compat.decode(out)
156
156
157 try:
157 try:
158 CommandLineToArgvW = ctypes.windll.shell32.CommandLineToArgvW
158 CommandLineToArgvW = ctypes.windll.shell32.CommandLineToArgvW
@@ -15,9 +15,6 b' This file is meant to be used by process.py'
15 import os, sys, threading
15 import os, sys, threading
16 import ctypes, msvcrt
16 import ctypes, msvcrt
17
17
18 # local imports
19 from . import py3compat
20
21 # Win32 API types needed for the API calls
18 # Win32 API types needed for the API calls
22 from ctypes import POINTER
19 from ctypes import POINTER
23 from ctypes.wintypes import HANDLE, HLOCAL, LPVOID, WORD, DWORD, BOOL, \
20 from ctypes.wintypes import HANDLE, HLOCAL, LPVOID, WORD, DWORD, BOOL, \
@@ -8,6 +8,7 b' Utilities for working with external processes.'
8
8
9
9
10 import os
10 import os
11 import shutil
11 import sys
12 import sys
12
13
13 if sys.platform == 'win32':
14 if sys.platform == 'win32':
@@ -18,7 +19,6 b' else:'
18 from ._process_posix import system, getoutput, arg_split, check_pid
19 from ._process_posix import system, getoutput, arg_split, check_pid
19
20
20 from ._process_common import getoutputerror, get_output_error_code, process_handler
21 from ._process_common import getoutputerror, get_output_error_code, process_handler
21 from . import py3compat
22
22
23
23
24 class FindCmdError(Exception):
24 class FindCmdError(Exception):
@@ -44,7 +44,7 b' def find_cmd(cmd):'
44 cmd : str
44 cmd : str
45 The command line program to look for.
45 The command line program to look for.
46 """
46 """
47 path = py3compat.which(cmd)
47 path = shutil.which(cmd)
48 if path is None:
48 if path is None:
49 raise FindCmdError('command could not be found: %s' % cmd)
49 raise FindCmdError('command could not be found: %s' % cmd)
50 return path
50 return path
@@ -1,5 +1,8 b''
1 # coding: utf-8
1 # coding: utf-8
2 """Compatibility tricks for Python 3. Mainly to do with unicode."""
2 """Compatibility tricks for Python 3. Mainly to do with unicode.
3
4 This file is deprecated and will be removed in a future version.
5 """
3 import functools
6 import functools
4 import os
7 import os
5 import sys
8 import sys
@@ -47,11 +50,11 b' def _modify_str_or_docstring(str_change_func):'
47 else:
50 else:
48 func = func_or_str
51 func = func_or_str
49 doc = func.__doc__
52 doc = func.__doc__
50
53
51 # PYTHONOPTIMIZE=2 strips docstrings, so they can disappear unexpectedly
54 # PYTHONOPTIMIZE=2 strips docstrings, so they can disappear unexpectedly
52 if doc is not None:
55 if doc is not None:
53 doc = str_change_func(doc)
56 doc = str_change_func(doc)
54
57
55 if func:
58 if func:
56 func.__doc__ = doc
59 func.__doc__ = doc
57 return func
60 return func
@@ -88,7 +91,7 b' def _shutil_which(cmd, mode=os.F_OK | os.X_OK, path=None):'
88 `mode` defaults to os.F_OK | os.X_OK. `path` defaults to the result
91 `mode` defaults to os.F_OK | os.X_OK. `path` defaults to the result
89 of os.environ.get("PATH"), or can be overridden with a custom search
92 of os.environ.get("PATH"), or can be overridden with a custom search
90 path.
93 path.
91
94
92 This is a backport of shutil.which from Python 3.4
95 This is a backport of shutil.which from Python 3.4
93 """
96 """
94 # Check that a given file can be accessed with the correct mode.
97 # Check that a given file can be accessed with the correct mode.
@@ -143,153 +146,72 b' def _shutil_which(cmd, mode=os.F_OK | os.X_OK, path=None):'
143 return name
146 return name
144 return None
147 return None
145
148
146 if sys.version_info[0] >= 3:
149 PY3 = True
147 PY3 = True
148
149 # keep reference to builtin_mod because the kernel overrides that value
150 # to forward requests to a frontend.
151 def input(prompt=''):
152 return builtin_mod.input(prompt)
153
154 builtin_mod_name = "builtins"
155 import builtins as builtin_mod
156
157 str_to_unicode = no_code
158 unicode_to_str = no_code
159 str_to_bytes = encode
160 bytes_to_str = decode
161 cast_bytes_py2 = no_code
162 cast_unicode_py2 = no_code
163 buffer_to_bytes_py2 = no_code
164
165 string_types = (str,)
166 unicode_type = str
167
168 which = shutil.which
169
170 def isidentifier(s, dotted=False):
171 if dotted:
172 return all(isidentifier(a) for a in s.split("."))
173 return s.isidentifier()
174
175 xrange = range
176 def iteritems(d): return iter(d.items())
177 def itervalues(d): return iter(d.values())
178 getcwd = os.getcwd
179
180 MethodType = types.MethodType
181
182 def execfile(fname, glob, loc=None, compiler=None):
183 loc = loc if (loc is not None) else glob
184 with open(fname, 'rb') as f:
185 compiler = compiler or compile
186 exec(compiler(f.read(), fname, 'exec'), glob, loc)
187
188 # Refactor print statements in doctests.
189 _print_statement_re = re.compile(r"\bprint (?P<expr>.*)$", re.MULTILINE)
190 def _print_statement_sub(match):
191 expr = match.groups('expr')
192 return "print(%s)" % expr
193
194 @_modify_str_or_docstring
195 def doctest_refactor_print(doc):
196 """Refactor 'print x' statements in a doctest to print(x) style. 2to3
197 unfortunately doesn't pick up on our doctests.
198
199 Can accept a string or a function, so it can be used as a decorator."""
200 return _print_statement_re.sub(_print_statement_sub, doc)
201
202 # Abstract u'abc' syntax:
203 @_modify_str_or_docstring
204 def u_format(s):
205 """"{u}'abc'" --> "'abc'" (Python 3)
206
207 Accepts a string or a function, so it can be used as a decorator."""
208 return s.format(u='')
209
210 def get_closure(f):
211 """Get a function's closure attribute"""
212 return f.__closure__
213
214 else:
215 PY3 = False
216
217 # keep reference to builtin_mod because the kernel overrides that value
218 # to forward requests to a frontend.
219 def input(prompt=''):
220 return builtin_mod.raw_input(prompt)
221
222 builtin_mod_name = "__builtin__"
223 import __builtin__ as builtin_mod
224
225 str_to_unicode = decode
226 unicode_to_str = encode
227 str_to_bytes = no_code
228 bytes_to_str = no_code
229 cast_bytes_py2 = cast_bytes
230 cast_unicode_py2 = cast_unicode
231 buffer_to_bytes_py2 = buffer_to_bytes
232
233 string_types = (str, unicode)
234 unicode_type = unicode
235
236 import re
237 _name_re = re.compile(r"[a-zA-Z_][a-zA-Z0-9_]*$")
238 def isidentifier(s, dotted=False):
239 if dotted:
240 return all(isidentifier(a) for a in s.split("."))
241 return bool(_name_re.match(s))
242
243 xrange = xrange
244 def iteritems(d): return d.iteritems()
245 def itervalues(d): return d.itervalues()
246 getcwd = os.getcwdu
247
248 def MethodType(func, instance):
249 return types.MethodType(func, instance, type(instance))
250
251 def doctest_refactor_print(func_or_str):
252 return func_or_str
253
254 def get_closure(f):
255 """Get a function's closure attribute"""
256 return f.func_closure
257
258 which = _shutil_which
259
260 # Abstract u'abc' syntax:
261 @_modify_str_or_docstring
262 def u_format(s):
263 """"{u}'abc'" --> "u'abc'" (Python 2)
264
265 Accepts a string or a function, so it can be used as a decorator."""
266 return s.format(u='u')
267
268 if sys.platform == 'win32':
269 def execfile(fname, glob=None, loc=None, compiler=None):
270 loc = loc if (loc is not None) else glob
271 scripttext = builtin_mod.open(fname).read()+ '\n'
272 # compile converts unicode filename to str assuming
273 # ascii. Let's do the conversion before calling compile
274 if isinstance(fname, unicode):
275 filename = unicode_to_str(fname)
276 else:
277 filename = fname
278 compiler = compiler or compile
279 exec(compiler(scripttext, filename, 'exec'), glob, loc)
280
150
281 else:
151 # keep reference to builtin_mod because the kernel overrides that value
282 def execfile(fname, glob=None, loc=None, compiler=None):
152 # to forward requests to a frontend.
283 if isinstance(fname, unicode):
153 def input(prompt=''):
284 filename = fname.encode(sys.getfilesystemencoding())
154 return builtin_mod.input(prompt)
285 else:
155
286 filename = fname
156 builtin_mod_name = "builtins"
287 where = [ns for ns in [glob, loc] if ns is not None]
157 import builtins as builtin_mod
288 if compiler is None:
158
289 builtin_mod.execfile(filename, *where)
159 str_to_unicode = no_code
290 else:
160 unicode_to_str = no_code
291 scripttext = builtin_mod.open(fname).read().rstrip() + '\n'
161 str_to_bytes = encode
292 exec(compiler(scripttext, filename, 'exec'), glob, loc)
162 bytes_to_str = decode
163 cast_bytes_py2 = no_code
164 cast_unicode_py2 = no_code
165 buffer_to_bytes_py2 = no_code
166
167 string_types = (str,)
168 unicode_type = str
169
170 which = shutil.which
171
172 def isidentifier(s, dotted=False):
173 if dotted:
174 return all(isidentifier(a) for a in s.split("."))
175 return s.isidentifier()
176
177 xrange = range
178 def iteritems(d): return iter(d.items())
179 def itervalues(d): return iter(d.values())
180 getcwd = os.getcwd
181
182 MethodType = types.MethodType
183
184 def execfile(fname, glob, loc=None, compiler=None):
185 loc = loc if (loc is not None) else glob
186 with open(fname, 'rb') as f:
187 compiler = compiler or compile
188 exec(compiler(f.read(), fname, 'exec'), glob, loc)
189
190 # Refactor print statements in doctests.
191 _print_statement_re = re.compile(r"\bprint (?P<expr>.*)$", re.MULTILINE)
192 def _print_statement_sub(match):
193 expr = match.groups('expr')
194 return "print(%s)" % expr
195
196 @_modify_str_or_docstring
197 def doctest_refactor_print(doc):
198 """Refactor 'print x' statements in a doctest to print(x) style. 2to3
199 unfortunately doesn't pick up on our doctests.
200
201 Can accept a string or a function, so it can be used as a decorator."""
202 return _print_statement_re.sub(_print_statement_sub, doc)
203
204 # Abstract u'abc' syntax:
205 @_modify_str_or_docstring
206 def u_format(s):
207 """"{u}'abc'" --> "'abc'" (Python 3)
208
209 Accepts a string or a function, so it can be used as a decorator."""
210 return s.format(u='')
211
212 def get_closure(f):
213 """Get a function's closure attribute"""
214 return f.__closure__
293
215
294
216
295 PY2 = not PY3
217 PY2 = not PY3
@@ -91,11 +91,7 b" Expfloat = r'[0-9]+' + Exponent"
91 Floatnumber = group(Pointfloat, Expfloat)
91 Floatnumber = group(Pointfloat, Expfloat)
92 Imagnumber = group(r'[0-9]+[jJ]', Floatnumber + r'[jJ]')
92 Imagnumber = group(r'[0-9]+[jJ]', Floatnumber + r'[jJ]')
93 Number = group(Imagnumber, Floatnumber, Intnumber)
93 Number = group(Imagnumber, Floatnumber, Intnumber)
94
94 StringPrefix = r'(?:[bB][rR]?|[rR][bB]?|[uU])?'
95 if sys.version_info.minor >= 3:
96 StringPrefix = r'(?:[bB][rR]?|[rR][bB]?|[uU])?'
97 else:
98 StringPrefix = r'(?:[bB]?[rR]?)?'
99
95
100 # Tail end of ' string.
96 # Tail end of ' string.
101 Single = r"[^'\\]*(?:\\.[^'\\]*)*'"
97 Single = r"[^'\\]*(?:\\.[^'\\]*)*'"
@@ -165,20 +161,18 b' for t in ("\'", \'"\','
165 "bR'", 'bR"', "BR'", 'BR"' ):
161 "bR'", 'bR"', "BR'", 'BR"' ):
166 single_quoted[t] = t
162 single_quoted[t] = t
167
163
168 if sys.version_info.minor >= 3:
164 for _prefix in ['rb', 'rB', 'Rb', 'RB', 'u', 'U']:
169 # Python 3.3
165 _t2 = _prefix+'"""'
170 for _prefix in ['rb', 'rB', 'Rb', 'RB', 'u', 'U']:
166 endprogs[_t2] = double3prog
171 _t2 = _prefix+'"""'
167 triple_quoted[_t2] = _t2
172 endprogs[_t2] = double3prog
168 _t1 = _prefix + "'''"
173 triple_quoted[_t2] = _t2
169 endprogs[_t1] = single3prog
174 _t1 = _prefix + "'''"
170 triple_quoted[_t1] = _t1
175 endprogs[_t1] = single3prog
171 single_quoted[_prefix+'"'] = _prefix+'"'
176 triple_quoted[_t1] = _t1
172 single_quoted[_prefix+"'"] = _prefix+"'"
177 single_quoted[_prefix+'"'] = _prefix+'"'
173 del _prefix, _t2, _t1
178 single_quoted[_prefix+"'"] = _prefix+"'"
174 endprogs['u'] = None
179 del _prefix, _t2, _t1
175 endprogs['U'] = None
180 endprogs['u'] = None
181 endprogs['U'] = None
182
176
183 del _compile
177 del _compile
184
178
@@ -8,10 +8,11 b' Writing code for Python 2 and 3'
8
8
9
9
10 IPython 6 requires Python 3, so our compatibility module
10 IPython 6 requires Python 3, so our compatibility module
11 ``IPython.utils.py3compat`` is deprecated. In most cases, we recommend you use
11 ``IPython.utils.py3compat`` is deprecated and will be removed in a future
12 the `six module <https://pythonhosted.org/six/>`__ to support compatible code.
12 version. In most cases, we recommend you use the `six module
13 This is widely used by other projects, so it is familiar to many developers and
13 <https://pythonhosted.org/six/>`__ to support compatible code. This is widely
14 thoroughly battle-tested.
14 used by other projects, so it is familiar to many developers and thoroughly
15 battle-tested.
15
16
16 Our ``py3compat`` module provided some more specific unicode conversions than
17 Our ``py3compat`` module provided some more specific unicode conversions than
17 those offered by ``six``. If you want to use these, copy them into your own code
18 those offered by ``six``. If you want to use these, copy them into your own code
@@ -40,15 +40,9 b' def oscmd(s):'
40 print(">", s)
40 print(">", s)
41 os.system(s)
41 os.system(s)
42
42
43 # Py3 compatibility hacks, without assuming IPython itself is installed with
43 def execfile(fname, globs, locs=None):
44 # the full py3compat machinery.
44 locs = locs or globs
45
45 exec(compile(open(fname).read(), fname, "exec"), globs, locs)
46 try:
47 execfile
48 except NameError:
49 def execfile(fname, globs, locs=None):
50 locs = locs or globs
51 exec(compile(open(fname).read(), fname, "exec"), globs, locs)
52
46
53 # A little utility we'll need below, since glob() does NOT allow you to do
47 # A little utility we'll need below, since glob() does NOT allow you to do
54 # exclusion on multiple endings!
48 # exclusion on multiple endings!
1 NO CONTENT: file was removed
NO CONTENT: file was removed
General Comments 0
You need to be logged in to leave comments. Login now