##// END OF EJS Templates
Release 5.0.0b4...
Release 5.0.0b4 What's new since b3: Small delay since last beta release, sorry about that, a few reasons though: - We / I slowed down a bit on the beta release pace, there was a few bugs/issues/User interface annoyance that needed a new version of prompt_toolkit to be released, there was no reasons to make extra-beta without this new version released. - We backed-down on some changes on which we had a few disagrements (more below). - I got sick, and had to catch up with backlog. Anyway, Jonathan release prompt_toolkit 1.0.1 and 1.0.2, so even if you don't try this new beta, upgrading prompt_toolkit will fix some of your issues. == Move back `TerminalInteractiveShell` to it's old place. This is a bigger breaking change since 5.0b3, the `TerminalInteractiveshell` moved back from `IPython.terminal.ptshell` to `IPython.terminal.interactiveshell`, if you've updated your project recently to adapt to this change we're sorry, but despite the fact that the version pre 5.0 and post 5.0 are relatively different the cost of conditional import for project depending on us appeared to be too high. So it's now easier to migrate from 4.0 to 5.0 as the class have the same name, and same location == Option name and default changed. `TerminalInteractiveShell.display_completions_in_column` is now gone. It was not present on 4.x so no API breakage there, and is now replaced by `TerminalInteractiveShell.display_completions` and is a enum that gained a 3rd mode for the completer: `readlinelike` for those of you that regret readline. This give us more flexibility for further options. Would appreciate testing of this new layout from vi user. The two other mode now being `column` and `multicolumn`. By popular request, `multicolumn` is not the default value for the previous option. == bug fixed: - quit/exit broken in ipdb - Copy/Past broken on windowm - Unicode broken on windows - function signature garbled when using `object?` - issue with paging text with `?` - completer could get stuck. See the complete git log for more informations.

File last commit:

r22148:9bf4fac3
r22560:1b487f7a
Show More
dir2.py
81 lines | 2.1 KiB | text/x-python | PythonLexer
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 # encoding: utf-8
"""A fancy version of Python's builtin :func:`dir` function.
"""
Thomas Kluyver
Consolidate code to check for method in IPython.utils.dir2
r22148 # Copyright (c) IPython Development Team.
# Distributed under the terms of the Modified BSD License.
Thomas Kluyver
Replace references to unicode and basestring
r13353
Thomas Kluyver
Consolidate code to check for method in IPython.utils.dir2
r22148 import inspect
from .py3compat import string_types
Brian Granger
Work to address the review comments on Fernando's branch....
r2498
Jeffrey Tratner
Use safe_hasattr in dir2...
r12965
def safe_hasattr(obj, attr):
"""In recent versions of Python, hasattr() only catches AttributeError.
This catches all errors.
"""
try:
getattr(obj, attr)
return True
except:
return False
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 def dir2(obj):
"""dir2(obj) -> list of strings
Extended version of the Python builtin dir(), which does a few extra
Anthony Sottile
Remove mention of Traits (removed in e1ced0b3)
r21849 checks.
Brian Granger
Work to address the review comments on Fernando's branch....
r2498
This version is guaranteed to return only a list of true strings, whereas
dir() returns anything that objects inject into themselves, even if they
are later not really valid for attribute access (many extension libraries
have such bugs).
"""
# Start building the attribute list via dir(), and then complete it
# with a few extra special-purpose calls.
sunny
Silence exception thrown by completer when dir() does not return a list
r16549 try:
words = set(dir(obj))
sunny
Remove bare except
r16653 except Exception:
sunny
Silence exception thrown by completer when dir() does not return a list
r16549 # TypeError: dir(obj) does not return a list
words = set()
Brian Granger
Work to address the review comments on Fernando's branch....
r2498
# filter out non-string attributes which may be stuffed by dir() calls
# and poor coding in third-party modules
Thomas Kluyver
Replace references to unicode and basestring
r13353 words = [w for w in words if isinstance(w, string_types)]
Tim Couper
Changes to dir2 to remove duplicates fix: put limit_to__all__ default to 0 fix: the doctest to reflect the new limit_to__all__...
r6310 return sorted(words)
Thomas Kluyver
Consolidate code to check for method in IPython.utils.dir2
r22148
def get_real_method(obj, name):
"""Like getattr, but with a few extra sanity checks:
- If obj is a class, ignore its methods
- Check if obj is a proxy that claims to have all attributes
- Catch attribute access failing with any exception
- Check that the attribute is a callable object
Returns the method or None.
"""
if inspect.isclass(obj):
return None
try:
canary = getattr(obj, '_ipython_canary_method_should_not_exist_', None)
except Exception:
return None
if canary is not None:
# It claimed to have an attribute it should never have
return None
try:
m = getattr(obj, name, None)
except Exception:
return None
if callable(m):
return m
return None