##// END OF EJS Templates
First step in reintegrating Jedi...
First step in reintegrating Jedi If Jedi is installed expose a private API use it with prompt toolkit. Jedi does not _yet_ provide all the completion IPython has, so this is still a bit awkward. In order to debug this (and see what is Jedi provided we for now inject a fake Jedi/IPython delimiter in the menu. Jedi completion and this behavior are enabled by default, but could likely be opt-in. Add also a number of debug flags to be able to track why jedi is not working, and/or what completions are found by IPython and not Jedi. That should give us a bit of heads up and feedback to know whether we can remove part of the IPython completer, and more especially if we can drop `python_matches`. Once `python_matches` is dropped and some other of the current matchers are either dropped or converted to the new API, that should simplify the internal quite a bit. That would just be too much for an already BIG pull-request.

File last commit:

r22963:2961b531
r23284:3ff1be2e
Show More
refbug.py
47 lines | 1.5 KiB | text/x-python | PythonLexer
Fernando Perez
Work again on bug 269966....
r1916 """Minimal script to reproduce our nasty reference counting bug.
Thomas Kluyver
Replace links to launchpad bugs in comments/docstrings with equivalent github links.
r3917 The problem is related to https://github.com/ipython/ipython/issues/141
Fernando Perez
Work again on bug 269966....
r1916
Fernando Perez
Small formatting fixes to address Jorgen's last code review.
r1922 The original fix for that appeared to work, but John D. Hunter found a
matplotlib example which, when run twice in a row, would break. The problem
were references held by open figures to internals of Tkinter.
Fernando Perez
Work again on bug 269966....
r1916
Fernando Perez
Small formatting fixes to address Jorgen's last code review.
r1922 This code reproduces the problem that John saw, without matplotlib.
This script is meant to be called by other parts of the test suite that call it
Thomas Kluyver
Replace links to launchpad bugs in comments/docstrings with equivalent github links.
r3917 via %run as if it were executed interactively by the user. As of 2011-05-29,
test_run.py calls it.
Fernando Perez
Work again on bug 269966....
r1916 """
#-----------------------------------------------------------------------------
# Module imports
#-----------------------------------------------------------------------------
import sys
MinRK
don't use deprecated ipapi.get...
r10581 from IPython import get_ipython
Fernando Perez
Work again on bug 269966....
r1916
#-----------------------------------------------------------------------------
# Globals
#-----------------------------------------------------------------------------
Brian Granger
Fixing InteractiveShell creation
r2746 # This needs to be here because nose and other test runners will import
# this module. Importing this module has potential side effects that we
# want to prevent.
if __name__ == '__main__':
Fernando Perez
Work again on bug 269966....
r1916
MinRK
don't use deprecated ipapi.get...
r10581 ip = get_ipython()
Fernando Perez
Work again on bug 269966....
r1916
Brian Granger
Fixing InteractiveShell creation
r2746 if not '_refbug_cache' in ip.user_ns:
ip.user_ns['_refbug_cache'] = []
Fernando Perez
Work again on bug 269966....
r1916
Brian Granger
Fixing InteractiveShell creation
r2746 aglobal = 'Hello'
def f():
return aglobal
cache = ip.user_ns['_refbug_cache']
cache.append(f)
def call_f():
for func in cache:
Thomas Kluyver
Convert print statements to print function calls...
r13348 print('lowercased:',func().lower())