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. |
|
221 | out = py3compat.decode(out) | |
222 |
err = py3compat. |
|
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 = 4 |
|
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 |
|
|
1161 | # we want to see exceptions in a reversed order: | |
1163 |
|
|
1162 | # the first exception should be on top | |
1164 |
|
|
1163 | for formatted_exception in reversed(formatted_exceptions): | |
1165 |
|
|
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 |
|
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( |
|
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( |
|
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 |
|
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 = |
|
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 = |
|
107 | shell.system = types.MethodType(xsys, shell) | |
108 |
|
108 | |||
109 |
shell._showtraceback = |
|
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 |
|
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( |
|
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 |
|
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( |
|
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. |
|
212 | out, err = p.communicate(input=py3compat.encode('\n'.join(commands)) or None) | |
214 |
out, err = py3compat. |
|
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. |
|
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. |
|
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. |
|
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. |
|
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. |
|
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 = |
|
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 |
|
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