frontend.py
73 lines
| 2.8 KiB
| text/x-python
|
PythonLexer
/ IPython / frontend.py
Fernando Perez
|
r11015 | """ | ||
Shim to maintain backwards compatibility with old frontend imports. | ||||
We have moved all contents of the old `frontend` subpackage into top-level | ||||
Fernando Perez
|
r11024 | subpackages (`html`, `qt` and `terminal`). | ||
This will let code that was making `from IPython.frontend...` calls continue | ||||
working, though a warning will be printed. | ||||
Fernando Perez
|
r11015 | """ | ||
#----------------------------------------------------------------------------- | ||||
# Copyright (c) 2013, IPython Development Team. | ||||
# | ||||
# Distributed under the terms of the Modified BSD License. | ||||
# | ||||
# The full license is in the file COPYING.txt, distributed with this software. | ||||
#----------------------------------------------------------------------------- | ||||
#----------------------------------------------------------------------------- | ||||
# Imports | ||||
#----------------------------------------------------------------------------- | ||||
from __future__ import print_function | ||||
Fernando Perez
|
r11019 | |||
# Stdlib | ||||
Fernando Perez
|
r11008 | import sys | ||
import types | ||||
Fernando Perez
|
r11020 | from warnings import warn | ||
Fernando Perez
|
r11008 | |||
Fernando Perez
|
r11020 | warn("The top-level `frontend` package has been deprecated. " | ||
"All its subpackages have been moved to the top `IPython` level.") | ||||
Fernando Perez
|
r11019 | |||
Fernando Perez
|
r11015 | #----------------------------------------------------------------------------- | ||
# Class declarations | ||||
#----------------------------------------------------------------------------- | ||||
Fernando Perez
|
r11008 | |||
class ShimModule(types.ModuleType): | ||||
def __getattribute__(self, key): | ||||
Fernando Perez
|
r11019 | # Use the equivalent of import_item(name), see below | ||
name = 'IPython.' + key | ||||
# NOTE: the code below is copied *verbatim* from | ||||
# importstring.import_item. For some very strange reason that makes no | ||||
# sense to me, if we call it *as a function*, it doesn't work. This | ||||
# has something to do with the deep bowels of the import machinery and | ||||
# I couldn't find a way to make the code work as a standard function | ||||
# call. But at least since it's an unmodified copy of import_item, | ||||
# which is used extensively and has a test suite, we can be reasonably | ||||
# confident this is OK. If anyone finds how to call the function, all | ||||
# the below could be replaced simply with: | ||||
# | ||||
# from IPython.utils.importstring import import_item | ||||
# return import_item('IPython.' + key) | ||||
Fernando Perez
|
r11015 | |||
Fernando Perez
|
r11019 | parts = name.rsplit('.', 1) | ||
if len(parts) == 2: | ||||
# called with 'foo.bar....' | ||||
package, obj = parts | ||||
module = __import__(package, fromlist=[obj]) | ||||
try: | ||||
pak = module.__dict__[obj] | ||||
except KeyError: | ||||
raise ImportError('No module named %s' % obj) | ||||
return pak | ||||
else: | ||||
# called with un-dotted string | ||||
return __import__(parts[0]) | ||||
Fernando Perez
|
r11008 | |||
Fernando Perez
|
r11015 | |||
# Unconditionally insert the shim into sys.modules so that further import calls | ||||
# trigger the custom attribute access above | ||||
Fernando Perez
|
r11008 | sys.modules['IPython.frontend'] = ShimModule('frontend') | ||