Show More
@@ -0,0 +1,50 | |||
|
1 | """Backwards compatibility - we use contextlib.nested to support Python 2.6, | |
|
2 | but it's removed in Python 3.2.""" | |
|
3 | ||
|
4 | # TODO : Remove this once we drop support for Python 2.6, and use | |
|
5 | # "with a, b:" instead. | |
|
6 | ||
|
7 | from contextlib import contextmanager | |
|
8 | ||
|
9 | @contextmanager | |
|
10 | def nested(*managers): | |
|
11 | """Combine multiple context managers into a single nested context manager. | |
|
12 | ||
|
13 | This function has been deprecated in favour of the multiple manager form | |
|
14 | of the with statement. | |
|
15 | ||
|
16 | The one advantage of this function over the multiple manager form of the | |
|
17 | with statement is that argument unpacking allows it to be | |
|
18 | used with a variable number of context managers as follows: | |
|
19 | ||
|
20 | with nested(*managers): | |
|
21 | do_something() | |
|
22 | ||
|
23 | """ | |
|
24 | warn("With-statements now directly support multiple context managers", | |
|
25 | DeprecationWarning, 3) | |
|
26 | exits = [] | |
|
27 | vars = [] | |
|
28 | exc = (None, None, None) | |
|
29 | try: | |
|
30 | for mgr in managers: | |
|
31 | exit = mgr.__exit__ | |
|
32 | enter = mgr.__enter__ | |
|
33 | vars.append(enter()) | |
|
34 | exits.append(exit) | |
|
35 | yield vars | |
|
36 | except: | |
|
37 | exc = sys.exc_info() | |
|
38 | finally: | |
|
39 | while exits: | |
|
40 | exit = exits.pop() | |
|
41 | try: | |
|
42 | if exit(*exc): | |
|
43 | exc = (None, None, None) | |
|
44 | except: | |
|
45 | exc = sys.exc_info() | |
|
46 | if exc != (None, None, None): | |
|
47 | # Don't rely on sys.exc_info() still containing | |
|
48 | # the right information. Another exception may | |
|
49 | # have been raised and caught by an exit method | |
|
50 | raise exc[0], exc[1], exc[2] |
@@ -29,7 +29,10 import re | |||
|
29 | 29 | import sys |
|
30 | 30 | import tempfile |
|
31 | 31 | import types |
|
32 | from contextlib import nested | |
|
32 | try: | |
|
33 | from contextlib import nested | |
|
34 | except: | |
|
35 | from IPython.utils.nested_context import nested | |
|
33 | 36 | |
|
34 | 37 | from IPython.config.configurable import SingletonConfigurable |
|
35 | 38 | from IPython.core import debugger, oinspect |
@@ -26,7 +26,10 from __future__ import with_statement | |||
|
26 | 26 | import __main__ |
|
27 | 27 | |
|
28 | 28 | import sys |
|
29 | from contextlib import nested | |
|
29 | try: | |
|
30 | from contextlib import nested | |
|
31 | except: | |
|
32 | from IPython.utils.nested_context import nested | |
|
30 | 33 | |
|
31 | 34 | from IPython.core import ultratb |
|
32 | 35 | from IPython.frontend.terminal.interactiveshell import TerminalInteractiveShell |
@@ -16,11 +16,15 | |||
|
16 | 16 | |
|
17 | 17 | import __builtin__ |
|
18 | 18 | import bdb |
|
19 | from contextlib import nested | |
|
20 | 19 | import os |
|
21 | 20 | import re |
|
22 | 21 | import sys |
|
23 | 22 | |
|
23 | try: | |
|
24 | from contextlib import nested | |
|
25 | except: | |
|
26 | from IPython.utils.nested_context import nested | |
|
27 | ||
|
24 | 28 | from IPython.core.error import TryNext |
|
25 | 29 | from IPython.core.usage import interactive_usage, default_banner |
|
26 | 30 | from IPython.core.interactiveshell import InteractiveShell, InteractiveShellABC |
General Comments 0
You need to be logged in to leave comments.
Login now