diff options
author | Ivan Levkivskyi <levkivskyi@gmail.com> | 2017-03-10 22:52:35 (GMT) |
---|---|---|
committer | Brett Cannon <brettcannon@users.noreply.github.com> | 2017-03-10 22:52:35 (GMT) |
commit | 4b2a2a425a906c8e4eb8daee14ab1793e225f726 (patch) | |
tree | b6e258cca5d1414386eaca01e29bb6749d1bb2a7 /Doc/library/dis.rst | |
parent | 740025478dcd0e9e4028507f32375c85f849fb07 (diff) | |
download | cpython-4b2a2a425a906c8e4eb8daee14ab1793e225f726.zip cpython-4b2a2a425a906c8e4eb8daee14ab1793e225f726.tar.gz cpython-4b2a2a425a906c8e4eb8daee14ab1793e225f726.tar.bz2 |
bpo-28810: Document changes to CALL_FUNCTION opcodes (GH-250)
Diffstat (limited to 'Doc/library/dis.rst')
-rw-r--r-- | Doc/library/dis.rst | 71 |
1 files changed, 40 insertions, 31 deletions
diff --git a/Doc/library/dis.rst b/Doc/library/dis.rst index 0c27653..d37f76f 100644 --- a/Doc/library/dis.rst +++ b/Doc/library/dis.rst @@ -1009,21 +1009,52 @@ All of the following opcodes use their arguments. .. opcode:: CALL_FUNCTION (argc) - Calls a function. The low byte of *argc* indicates the number of positional - parameters, the high byte the number of keyword parameters. On the stack, the - opcode finds the keyword parameters first. For each keyword argument, the - value is on top of the key. Below the keyword parameters, the positional - parameters are on the stack, with the right-most parameter on top. Below the - parameters, the function object to call is on the stack. Pops all function - arguments, and the function itself off the stack, and pushes the return - value. + Calls a function. *argc* indicates the number of positional arguments. + The positional arguments are on the stack, with the right-most argument + on top. Below the arguments, the function object to call is on the stack. + Pops all function arguments, and the function itself off the stack, and + pushes the return value. + + .. versionchanged:: 3.6 + This opcode is used only for calls with positional arguments. + + +.. opcode:: CALL_FUNCTION_KW (argc) + + Calls a function. *argc* indicates the number of arguments (positional + and keyword). The top element on the stack contains a tuple of keyword + argument names. Below the tuple, keyword arguments are on the stack, in + the order corresponding to the tuple. Below the keyword arguments, the + positional arguments are on the stack, with the right-most parameter on + top. Below the arguments, the function object to call is on the stack. + Pops all function arguments, and the function itself off the stack, and + pushes the return value. + + .. versionchanged:: 3.6 + Keyword arguments are packed in a tuple instead of a dictionary, + *argc* indicates the total number of arguments + + +.. opcode:: CALL_FUNCTION_EX (flags) + + Calls a function. The lowest bit of *flags* indicates whether the + var-keyword argument is placed at the top of the stack. Below the + var-keyword argument, the var-positional argument is on the stack. + Below the arguments, the function object to call is placed. + Pops all function arguments, and the function itself off the stack, and + pushes the return value. Note that this opcode pops at most three items + from the stack. Var-positional and var-keyword arguments are packed + by :opcode:`BUILD_MAP_UNPACK_WITH_CALL` and + :opcode:`BUILD_MAP_UNPACK_WITH_CALL`. + + .. versionadded:: 3.6 .. opcode:: LOAD_METHOD (namei) Loads a method named ``co_names[namei]`` from TOS object. TOS is popped and method and TOS are pushed when interpreter can call unbound method directly. - TOS will be uesd as the first argument (``self``) by :opcode:`CALL_METHOD`. + TOS will be used as the first argument (``self``) by :opcode:`CALL_METHOD`. Otherwise, ``NULL`` and method is pushed (method is bound method or something else). @@ -1071,28 +1102,6 @@ All of the following opcodes use their arguments. two most-significant bytes. -.. opcode:: CALL_FUNCTION_VAR (argc) - - Calls a function. *argc* is interpreted as in :opcode:`CALL_FUNCTION`. The - top element on the stack contains the variable argument list, followed by - keyword and positional arguments. - - -.. opcode:: CALL_FUNCTION_KW (argc) - - Calls a function. *argc* is interpreted as in :opcode:`CALL_FUNCTION`. The - top element on the stack contains the keyword arguments dictionary, followed - by explicit keyword and positional arguments. - - -.. opcode:: CALL_FUNCTION_VAR_KW (argc) - - Calls a function. *argc* is interpreted as in :opcode:`CALL_FUNCTION`. The - top element on the stack contains the keyword arguments dictionary, followed - by the variable-arguments tuple, followed by explicit keyword and positional - arguments. - - .. opcode:: FORMAT_VALUE (flags) Used for implementing formatted literal strings (f-strings). Pops |