##// END OF EJS Templates
add IPython.embed_kernel()...
add IPython.embed_kernel() This patch adds IPython.embed_kernel() as a public API. Embedding an IPython kernel in an application is useful when you want to use IPython.embed() but don't have a terminal attached on stdin and stdout. My use case is a modern gdb with Python API support #!/usr/bin/gdb --python import IPython; IPython.embed_kernel() this way I get to use ipython to explore the GDB API without the readline librarry in gdb and ipython fighting over the terminal settings. A Google search revealed that other people were interetsted in this use case as well: http://mail.scipy.org/pipermail/ipython-dev/2011-July/007928.html

File last commit:

r5882:fd2691c8
r6041:25e21eb9
Show More
pyfile.py
23 lines | 840 B | text/x-python | PythonLexer
Thomas Kluyver
Find .py files for verbose tracebacks, rather than trying to tokenize .pyc files.
r5851 """Utilities for working with Python source files.
Exposes various functions from recent Python standard libraries, along with
equivalents for older Python versions.
"""
import os.path
try: # Python 3.2
from imp import source_from_cache, cache_from_source
except ImportError:
# Python <= 3.1: .pyc files go next to .py
def source_from_cache(path):
basename, ext = os.path.splitext(path)
Thomas
Fix syntax for Python 2.6 - no set literals.
r5882 if ext not in ('.pyc', '.pyo'):
Thomas Kluyver
Find .py files for verbose tracebacks, rather than trying to tokenize .pyc files.
r5851 raise ValueError('Not a cached Python file extension', ext)
# Should we look for .pyw files?
return basename + '.py'
def cache_from_source(path, debug_override=None):
if debug_override is None:
debug_override = __debug__
basename, ext = os.path.splitext(path)
return basename + '.pyc' if debug_override else '.pyo'