diff options
author | Victor Stinner <victor.stinner@gmail.com> | 2016-09-09 17:17:08 (GMT) |
---|---|---|
committer | Victor Stinner <victor.stinner@gmail.com> | 2016-09-09 17:17:08 (GMT) |
commit | f9b760f48ae2bd32ac347fe805b078a16037afee (patch) | |
tree | 5472de2d2cd70aab93c4ab4b00aabf7944caa11c /Lib/test/test_extcall.py | |
parent | e53592091afa172f97bf3d7af43041a28c6ff688 (diff) | |
download | cpython-f9b760f48ae2bd32ac347fe805b078a16037afee.zip cpython-f9b760f48ae2bd32ac347fe805b078a16037afee.tar.gz cpython-f9b760f48ae2bd32ac347fe805b078a16037afee.tar.bz2 |
Rework CALL_FUNCTION* opcodes
Issue #27213: Rework CALL_FUNCTION* opcodes to produce shorter and more
efficient bytecode:
* CALL_FUNCTION now only accepts position arguments
* CALL_FUNCTION_KW accepts position arguments and keyword arguments, but keys
of keyword arguments are packed into a constant tuple.
* CALL_FUNCTION_EX is the most generic, it expects a tuple and a dict for
positional and keyword arguments.
CALL_FUNCTION_VAR and CALL_FUNCTION_VAR_KW opcodes have been removed.
2 tests of test_traceback are currently broken: skip test, the issue #28050 was
created to track the issue.
Patch by Demur Rumed, design by Serhiy Storchaka, reviewed by Serhiy Storchaka
and Victor Stinner.
Diffstat (limited to 'Lib/test/test_extcall.py')
-rw-r--r-- | Lib/test/test_extcall.py | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/Lib/test/test_extcall.py b/Lib/test/test_extcall.py index 5eea379..55f1393 100644 --- a/Lib/test/test_extcall.py +++ b/Lib/test/test_extcall.py @@ -118,7 +118,7 @@ Verify clearing of SF bug #733667 >>> g(*Nothing()) Traceback (most recent call last): ... - TypeError: g() argument after * must be an iterable, not Nothing + TypeError: 'Nothing' object is not iterable >>> class Nothing: ... def __len__(self): return 5 @@ -127,7 +127,7 @@ Verify clearing of SF bug #733667 >>> g(*Nothing()) Traceback (most recent call last): ... - TypeError: g() argument after * must be an iterable, not Nothing + TypeError: 'Nothing' object is not iterable >>> class Nothing(): ... def __len__(self): return 5 @@ -231,34 +231,32 @@ What about willful misconduct? >>> h(*h) Traceback (most recent call last): ... - TypeError: h() argument after * must be an iterable, not function + TypeError: 'function' object is not iterable >>> dir(*h) Traceback (most recent call last): ... - TypeError: dir() argument after * must be an iterable, not function + TypeError: 'function' object is not iterable >>> None(*h) Traceback (most recent call last): ... - TypeError: NoneType object argument after * must be an iterable, \ -not function + TypeError: 'function' object is not iterable >>> h(**h) Traceback (most recent call last): ... - TypeError: h() argument after ** must be a mapping, not function + TypeError: 'function' object is not a mapping >>> dir(**h) Traceback (most recent call last): ... - TypeError: dir() argument after ** must be a mapping, not function + TypeError: 'function' object is not a mapping >>> None(**h) Traceback (most recent call last): ... - TypeError: NoneType object argument after ** must be a mapping, \ -not function + TypeError: 'function' object is not a mapping >>> dir(b=1, **{'b': 1}) Traceback (most recent call last): |