Show More
@@ -0,0 +1,1 b'' | |||
|
1 | * The module ``IPython.core.fakemodule`` has been removed. |
@@ -47,7 +47,6 b' from IPython.core.displayhook import DisplayHook' | |||
|
47 | 47 | from IPython.core.displaypub import DisplayPublisher |
|
48 | 48 | from IPython.core.error import UsageError |
|
49 | 49 | from IPython.core.extensions import ExtensionManager |
|
50 | from IPython.core.fakemodule import FakeModule, init_fakemod_dict | |
|
51 | 50 | from IPython.core.formatters import DisplayFormatter |
|
52 | 51 | from IPython.core.history import HistoryManager |
|
53 | 52 | from IPython.core.inputsplitter import IPythonInputSplitter, ESC_MAGIC, ESC_MAGIC2 |
@@ -826,15 +825,18 b' class InteractiveShell(SingletonConfigurable):' | |||
|
826 | 825 | # Things related to the "main" module |
|
827 | 826 | #------------------------------------------------------------------------- |
|
828 | 827 | |
|
829 | def new_main_mod(self, filename): | |
|
828 | def new_main_mod(self, filename, modname): | |
|
830 | 829 | """Return a new 'main' module object for user code execution. |
|
831 | 830 | |
|
832 | 831 | ``filename`` should be the path of the script which will be run in the |
|
833 | 832 | module. Requests with the same filename will get the same module, with |
|
834 | 833 | its namespace cleared. |
|
835 | 834 | |
|
835 | ``modname`` should be the module name - normally either '__main__' or | |
|
836 | the basename of the file without the extension. | |
|
837 | ||
|
836 | 838 | When scripts are executed via %run, we must keep a reference to their |
|
837 |
__main__ module |
|
|
839 | __main__ module around so that Python doesn't | |
|
838 | 840 | clear it, rendering references to module globals useless. |
|
839 | 841 | |
|
840 | 842 | This method keeps said reference in a private dict, keyed by the |
@@ -847,9 +849,16 b' class InteractiveShell(SingletonConfigurable):' | |||
|
847 | 849 | try: |
|
848 | 850 | main_mod = self._main_mod_cache[filename] |
|
849 | 851 | except KeyError: |
|
850 |
main_mod = self._main_mod_cache[filename] = |
|
|
852 | main_mod = self._main_mod_cache[filename] = types.ModuleType(modname, | |
|
853 | doc="Module created for script run in IPython") | |
|
851 | 854 | else: |
|
852 | init_fakemod_dict(main_mod) | |
|
855 | main_mod.__dict__.clear() | |
|
856 | main_mod.__name__ = modname | |
|
857 | ||
|
858 | main_mod.__file__ = filename | |
|
859 | # It seems pydoc (and perhaps others) needs any module instance to | |
|
860 | # implement a __nonzero__ method | |
|
861 | main_mod.__nonzero__ = lambda : True | |
|
853 | 862 | |
|
854 | 863 | return main_mod |
|
855 | 864 | |
@@ -863,7 +872,7 b' class InteractiveShell(SingletonConfigurable):' | |||
|
863 | 872 | |
|
864 | 873 | In [15]: import IPython |
|
865 | 874 | |
|
866 | In [16]: m = _ip.new_main_mod(IPython.__file__) | |
|
875 | In [16]: m = _ip.new_main_mod(IPython.__file__, 'IPython') | |
|
867 | 876 | |
|
868 | 877 | In [17]: len(_ip._main_mod_cache) > 0 |
|
869 | 878 | Out[17]: True |
@@ -550,6 +550,11 b' python-profiler package from non-free.""")' | |||
|
550 | 550 | __name__save = self.shell.user_ns['__name__'] |
|
551 | 551 | prog_ns['__name__'] = '__main__' |
|
552 | 552 | main_mod = self.shell.user_module |
|
553 | ||
|
554 | # Since '%run foo' emulates 'python foo.py' at the cmd line, we must | |
|
555 | # set the __file__ global in the script's namespace | |
|
556 | # TK: Is this necessary in interactive mode? | |
|
557 | prog_ns['__file__'] = filename | |
|
553 | 558 | else: |
|
554 | 559 | # Run in a fresh, empty namespace |
|
555 | 560 | if 'n' in opts: |
@@ -560,13 +565,8 b' python-profiler package from non-free.""")' | |||
|
560 | 565 | # The shell MUST hold a reference to prog_ns so after %run |
|
561 | 566 | # exits, the python deletion mechanism doesn't zero it out |
|
562 | 567 | # (leaving dangling references). See interactiveshell for details |
|
563 | main_mod = self.shell.new_main_mod(filename) | |
|
568 | main_mod = self.shell.new_main_mod(filename, name) | |
|
564 | 569 | prog_ns = main_mod.__dict__ |
|
565 | prog_ns['__name__'] = name | |
|
566 | ||
|
567 | # Since '%run foo' emulates 'python foo.py' at the cmd line, we must | |
|
568 | # set the __file__ global in the script's namespace | |
|
569 | prog_ns['__file__'] = filename | |
|
570 | 570 | |
|
571 | 571 | # pickle fix. See interactiveshell for an explanation. But we need to |
|
572 | 572 | # make sure that, if we overwrite __main__, we replace it at the end |
@@ -9,9 +9,6 b' def test_import_crashhandler():' | |||
|
9 | 9 | def test_import_debugger(): |
|
10 | 10 | from IPython.core import debugger |
|
11 | 11 | |
|
12 | def test_import_fakemodule(): | |
|
13 | from IPython.core import fakemodule | |
|
14 | ||
|
15 | 12 | def test_import_excolors(): |
|
16 | 13 | from IPython.core import excolors |
|
17 | 14 |
@@ -15,6 +15,7 b' from __future__ import absolute_import' | |||
|
15 | 15 | |
|
16 | 16 | import functools |
|
17 | 17 | import os |
|
18 | from os.path import join as pjoin | |
|
18 | 19 | import random |
|
19 | 20 | import sys |
|
20 | 21 | import tempfile |
@@ -360,6 +361,17 b' tclass.py: deleting object: C-third' | |||
|
360 | 361 | _ip.magic('run -t -N 1 %s' % self.fname) |
|
361 | 362 | _ip.magic('run -t -N 10 %s' % self.fname) |
|
362 | 363 | |
|
364 | def test_ignore_sys_exit(self): | |
|
365 | """Test the -e option to ignore sys.exit()""" | |
|
366 | src = "import sys; sys.exit(1)" | |
|
367 | self.mktmp(src) | |
|
368 | with tt.AssertPrints('SystemExit'): | |
|
369 | _ip.magic('run %s' % self.fname) | |
|
370 | ||
|
371 | with tt.AssertNotPrints('SystemExit'): | |
|
372 | _ip.magic('run -e %s' % self.fname) | |
|
373 | ||
|
374 | ||
|
363 | 375 | |
|
364 | 376 | class TestMagicRunWithPackage(unittest.TestCase): |
|
365 | 377 | |
@@ -398,6 +410,7 b' class TestMagicRunWithPackage(unittest.TestCase):' | |||
|
398 | 410 | self.tempdir.cleanup() |
|
399 | 411 | |
|
400 | 412 | def check_run_submodule(self, submodule, opts=''): |
|
413 | _ip.user_ns.pop('x', None) | |
|
401 | 414 | _ip.magic('run {2} -m {0}.{1}'.format(self.package, submodule, opts)) |
|
402 | 415 | self.assertEqual(_ip.user_ns['x'], self.value, |
|
403 | 416 | 'Variable `x` is not loaded from module `{0}`.' |
@@ -430,3 +443,16 b' class TestMagicRunWithPackage(unittest.TestCase):' | |||
|
430 | 443 | @with_fake_debugger |
|
431 | 444 | def test_debug_run_submodule_with_relative_import(self): |
|
432 | 445 | self.check_run_submodule('relative', '-d') |
|
446 | ||
|
447 | def test_run__name__(): | |
|
448 | with TemporaryDirectory() as td: | |
|
449 | path = pjoin(td, 'foo.py') | |
|
450 | with open(path, 'w') as f: | |
|
451 | f.write("q = __name__") | |
|
452 | ||
|
453 | _ip.user_ns.pop('q', None) | |
|
454 | _ip.magic('run {}'.format(path)) | |
|
455 | nt.assert_equal(_ip.user_ns.pop('q'), '__main__') | |
|
456 | ||
|
457 | _ip.magic('run -n {}'.format(path)) | |
|
458 | nt.assert_equal(_ip.user_ns.pop('q'), 'foo') |
@@ -27,7 +27,6 b' import inspect, os, sys, textwrap' | |||
|
27 | 27 | # Our own |
|
28 | 28 | from IPython.config.configurable import Configurable |
|
29 | 29 | from IPython.core.error import UsageError |
|
30 | from IPython.core.fakemodule import FakeModule | |
|
31 | 30 | from IPython.core.magic import Magics, magics_class, line_magic |
|
32 | 31 | from IPython.testing.skipdoctest import skip_doctest |
|
33 | 32 | from IPython.utils.traitlets import Bool |
@@ -224,7 +223,8 b' class StoreMagics(Magics, Configurable):' | |||
|
224 | 223 | raise UsageError("Unknown variable '%s'" % args[0]) |
|
225 | 224 | |
|
226 | 225 | else: |
|
227 |
|
|
|
226 | modname = getattr(inspect.getmodule(obj), '__name__', '') | |
|
227 | if modname == '__main__': | |
|
228 | 228 | print textwrap.dedent("""\ |
|
229 | 229 | Warning:%s is %s |
|
230 | 230 | Proper storage of interactively declared classes (or instances |
@@ -35,7 +35,7 b" if __name__ == '__main__':" | |||
|
35 | 35 | r'\.zmq', |
|
36 | 36 | ] |
|
37 | 37 | |
|
38 |
docwriter.module_skip_patterns += [ |
|
|
38 | docwriter.module_skip_patterns += [ | |
|
39 | 39 | r'\.testing\.iptest', |
|
40 | 40 | # Keeping these disabled is OK |
|
41 | 41 | r'\.parallel\.controller\.mongodb', |
|
1 | NO CONTENT: file was removed |
|
1 | NO CONTENT: file was removed |
General Comments 0
You need to be logged in to leave comments.
Login now