Commit 0c0da48a authored by Martin Panter's avatar Martin Panter

Issue #24136: Document generalized unpacking, PEP 448

Based on patches by Konstantin Molchanov and Neil Girdhar.
parent 0d18c15f
...@@ -177,7 +177,7 @@ The :mod:`functools` module defines the following functions: ...@@ -177,7 +177,7 @@ The :mod:`functools` module defines the following functions:
def newfunc(*fargs, **fkeywords): def newfunc(*fargs, **fkeywords):
newkeywords = keywords.copy() newkeywords = keywords.copy()
newkeywords.update(fkeywords) newkeywords.update(fkeywords)
return func(*(args + fargs), **newkeywords) return func(*args, *fargs, **newkeywords)
newfunc.func = func newfunc.func = func
newfunc.args = args newfunc.args = args
newfunc.keywords = keywords newfunc.keywords = keywords
......
...@@ -133,7 +133,7 @@ Parenthesized forms ...@@ -133,7 +133,7 @@ Parenthesized forms
A parenthesized form is an optional expression list enclosed in parentheses: A parenthesized form is an optional expression list enclosed in parentheses:
.. productionlist:: .. productionlist::
parenth_form: "(" [`expression_list`] ")" parenth_form: "(" [`starred_expression`] ")"
A parenthesized expression list yields whatever that expression list yields: if A parenthesized expression list yields whatever that expression list yields: if
the list contains at least one comma, it yields a tuple; otherwise, it yields the list contains at least one comma, it yields a tuple; otherwise, it yields
...@@ -202,7 +202,7 @@ A list display is a possibly empty series of expressions enclosed in square ...@@ -202,7 +202,7 @@ A list display is a possibly empty series of expressions enclosed in square
brackets: brackets:
.. productionlist:: .. productionlist::
list_display: "[" [`expression_list` | `comprehension`] "]" list_display: "[" [`starred_list` | `comprehension`] "]"
A list display yields a new list object, the contents being specified by either A list display yields a new list object, the contents being specified by either
a list of expressions or a comprehension. When a comma-separated list of a list of expressions or a comprehension. When a comma-separated list of
...@@ -223,7 +223,7 @@ A set display is denoted by curly braces and distinguishable from dictionary ...@@ -223,7 +223,7 @@ A set display is denoted by curly braces and distinguishable from dictionary
displays by the lack of colons separating keys and values: displays by the lack of colons separating keys and values:
.. productionlist:: .. productionlist::
set_display: "{" (`expression_list` | `comprehension`) "}" set_display: "{" (`starred_list` | `comprehension`) "}"
A set display yields a new mutable set object, the contents being specified by A set display yields a new mutable set object, the contents being specified by
either a sequence of expressions or a comprehension. When a comma-separated either a sequence of expressions or a comprehension. When a comma-separated
...@@ -250,7 +250,7 @@ curly braces: ...@@ -250,7 +250,7 @@ curly braces:
.. productionlist:: .. productionlist::
dict_display: "{" [`key_datum_list` | `dict_comprehension`] "}" dict_display: "{" [`key_datum_list` | `dict_comprehension`] "}"
key_datum_list: `key_datum` ("," `key_datum`)* [","] key_datum_list: `key_datum` ("," `key_datum`)* [","]
key_datum: `expression` ":" `expression` key_datum: `expression` ":" `expression` | "**" `or_expr`
dict_comprehension: `expression` ":" `expression` `comp_for` dict_comprehension: `expression` ":" `expression` `comp_for`
A dictionary display yields a new dictionary object. A dictionary display yields a new dictionary object.
...@@ -261,6 +261,16 @@ used as a key into the dictionary to store the corresponding datum. This means ...@@ -261,6 +261,16 @@ used as a key into the dictionary to store the corresponding datum. This means
that you can specify the same key multiple times in the key/datum list, and the that you can specify the same key multiple times in the key/datum list, and the
final dictionary's value for that key will be the last one given. final dictionary's value for that key will be the last one given.
.. index:: unpacking; dictionary, **; in dictionary displays
A double asterisk ``**`` denotes :dfn:`dictionary unpacking`.
Its operand must be a :term:`mapping`. Each mapping item is added
to the new dictionary. Later values replace values already set by
earlier key/datum pairs and earlier dictionary unpackings.
.. versionadded:: 3.5
Unpacking into dictionary displays, originally proposed by :pep:`448`.
A dict comprehension, in contrast to list and set comprehensions, needs two A dict comprehension, in contrast to list and set comprehensions, needs two
expressions separated with a colon followed by the usual "for" and "if" clauses. expressions separated with a colon followed by the usual "for" and "if" clauses.
When the comprehension is run, the resulting key and value elements are inserted When the comprehension is run, the resulting key and value elements are inserted
...@@ -649,15 +659,15 @@ series of :term:`arguments <argument>`: ...@@ -649,15 +659,15 @@ series of :term:`arguments <argument>`:
.. productionlist:: .. productionlist::
call: `primary` "(" [`argument_list` [","] | `comprehension`] ")" call: `primary` "(" [`argument_list` [","] | `comprehension`] ")"
argument_list: `positional_arguments` ["," `keyword_arguments`] argument_list: `positional_arguments` ["," `starred_and_keywords`]
: ["," "*" `expression`] ["," `keyword_arguments`] : ["," `keywords_arguments`]
: ["," "**" `expression`] : | `starred_and_keywords` ["," `keywords_arguments`]
: | `keyword_arguments` ["," "*" `expression`] : | `keywords_arguments`
: ["," `keyword_arguments`] ["," "**" `expression`] positional_arguments: ["*"] `expression` ("," ["*"] `expression`)*
: | "*" `expression` ["," `keyword_arguments`] ["," "**" `expression`] starred_and_keywords: ("*" `expression` | `keyword_item`)
: | "**" `expression` : ("," "*" `expression` | "," `keyword_item`)*
positional_arguments: `expression` ("," `expression`)* keywords_arguments: (`keyword_item` | "**" `expression`)
keyword_arguments: `keyword_item` ("," `keyword_item`)* : ("," `keyword_item` | "**" `expression`)*
keyword_item: `identifier` "=" `expression` keyword_item: `identifier` "=" `expression`
An optional trailing comma may be present after the positional and keyword arguments An optional trailing comma may be present after the positional and keyword arguments
...@@ -715,17 +725,18 @@ there were no excess keyword arguments. ...@@ -715,17 +725,18 @@ there were no excess keyword arguments.
.. index:: .. index::
single: *; in function calls single: *; in function calls
single: unpacking; in function calls
If the syntax ``*expression`` appears in the function call, ``expression`` must If the syntax ``*expression`` appears in the function call, ``expression`` must
evaluate to an iterable. Elements from this iterable are treated as if they evaluate to an :term:`iterable`. Elements from these iterables are
were additional positional arguments; if there are positional arguments treated as if they were additional positional arguments. For the call
*x1*, ..., *xN*, and ``expression`` evaluates to a sequence *y1*, ..., *yM*, ``f(x1, x2, *y, x3, x4)``, if *y* evaluates to a sequence *y1*, ..., *yM*,
this is equivalent to a call with M+N positional arguments *x1*, ..., *xN*, this is equivalent to a call with M+4 positional arguments *x1*, *x2*,
*y1*, ..., *yM*. *y1*, ..., *yM*, *x3*, *x4*.
A consequence of this is that although the ``*expression`` syntax may appear A consequence of this is that although the ``*expression`` syntax may appear
*after* some keyword arguments, it is processed *before* the keyword arguments *after* explicit keyword arguments, it is processed *before* the
(and the ``**expression`` argument, if any -- see below). So:: keyword arguments (and any ``**expression`` arguments -- see below). So::
>>> def f(a, b): >>> def f(a, b):
... print(a, b) ... print(a, b)
...@@ -746,13 +757,20 @@ used in the same call, so in practice this confusion does not arise. ...@@ -746,13 +757,20 @@ used in the same call, so in practice this confusion does not arise.
single: **; in function calls single: **; in function calls
If the syntax ``**expression`` appears in the function call, ``expression`` must If the syntax ``**expression`` appears in the function call, ``expression`` must
evaluate to a mapping, the contents of which are treated as additional keyword evaluate to a :term:`mapping`, the contents of which are treated as
arguments. In the case of a keyword appearing in both ``expression`` and as an additional keyword arguments. If a keyword is already present
explicit keyword argument, a :exc:`TypeError` exception is raised. (as an explicit keyword argument, or from another unpacking),
a :exc:`TypeError` exception is raised.
Formal parameters using the syntax ``*identifier`` or ``**identifier`` cannot be Formal parameters using the syntax ``*identifier`` or ``**identifier`` cannot be
used as positional argument slots or as keyword argument names. used as positional argument slots or as keyword argument names.
.. versionchanged:: 3.5
Function calls accept any number of ``*`` and ``**`` unpackings,
positional arguments may follow iterable unpackings (``*``),
and keyword arguments may follow dictionary unpackings (``**``).
Originally proposed by :pep:`448`.
A call always returns some value, possibly ``None``, unless it raises an A call always returns some value, possibly ``None``, unless it raises an
exception. How this value is computed depends on the type of the callable exception. How this value is computed depends on the type of the callable
object. object.
...@@ -1407,13 +1425,29 @@ Expression lists ...@@ -1407,13 +1425,29 @@ Expression lists
.. productionlist:: .. productionlist::
expression_list: `expression` ( "," `expression` )* [","] expression_list: `expression` ( "," `expression` )* [","]
starred_list: `starred_item` ( "," `starred_item` )* [","]
starred_expression: `expression` | ( `starred_item` "," )* [`starred_item`]
starred_item: `expression` | "*" `or_expr`
.. index:: object: tuple .. index:: object: tuple
An expression list containing at least one comma yields a tuple. The length of Except when part of a list or set display, an expression list
containing at least one comma yields a tuple. The length of
the tuple is the number of expressions in the list. The expressions are the tuple is the number of expressions in the list. The expressions are
evaluated from left to right. evaluated from left to right.
.. index::
pair: iterable; unpacking
single: *; in expression lists
An asterisk ``*`` denotes :dfn:`iterable unpacking`. Its operand must be
an :term:`iterable`. The iterable is expanded into a sequence of items,
which are included in the new tuple, list, or set, at the site of
the unpacking.
.. versionadded:: 3.5
Iterable unpacking in expression lists, originally proposed by :pep:`448`.
.. index:: pair: trailing; comma .. index:: pair: trailing; comma
The trailing comma is required only to create a single tuple (a.k.a. a The trailing comma is required only to create a single tuple (a.k.a. a
......
...@@ -45,7 +45,7 @@ expression statements are allowed and occasionally useful. The syntax for an ...@@ -45,7 +45,7 @@ expression statements are allowed and occasionally useful. The syntax for an
expression statement is: expression statement is:
.. productionlist:: .. productionlist::
expression_stmt: `expression_list` expression_stmt: `starred_expression`
An expression statement evaluates the expression list (which may be a single An expression statement evaluates the expression list (which may be a single
expression). expression).
...@@ -81,7 +81,7 @@ Assignment statements are used to (re)bind names to values and to modify ...@@ -81,7 +81,7 @@ Assignment statements are used to (re)bind names to values and to modify
attributes or items of mutable objects: attributes or items of mutable objects:
.. productionlist:: .. productionlist::
assignment_stmt: (`target_list` "=")+ (`expression_list` | `yield_expression`) assignment_stmt: (`target_list` "=")+ (`starred_expression` | `yield_expression`)
target_list: `target` ("," `target`)* [","] target_list: `target` ("," `target`)* [","]
target: `identifier` target: `identifier`
: | "(" `target_list` ")" : | "(" `target_list` ")"
...@@ -892,7 +892,7 @@ The :keyword:`nonlocal` statement ...@@ -892,7 +892,7 @@ The :keyword:`nonlocal` statement
nonlocal_stmt: "nonlocal" `identifier` ("," `identifier`)* nonlocal_stmt: "nonlocal" `identifier` ("," `identifier`)*
.. XXX add when implemented .. XXX add when implemented
: ["=" (`target_list` "=")+ expression_list] : ["=" (`target_list` "=")+ starred_expression]
: | "nonlocal" identifier augop expression_list : | "nonlocal" identifier augop expression_list
The :keyword:`nonlocal` statement causes the listed identifiers to refer to The :keyword:`nonlocal` statement causes the listed identifiers to refer to
......
...@@ -320,7 +320,7 @@ PEP 448 - Additional Unpacking Generalizations ...@@ -320,7 +320,7 @@ PEP 448 - Additional Unpacking Generalizations
:pep:`448` extends the allowed uses of the ``*`` iterable unpacking :pep:`448` extends the allowed uses of the ``*`` iterable unpacking
operator and ``**`` dictionary unpacking operator. It is now possible operator and ``**`` dictionary unpacking operator. It is now possible
to use an arbitrary number of unpackings in function calls:: to use an arbitrary number of unpackings in :ref:`function calls <calls>`::
>>> print(*[1], *[2], 3, *[4, 5]) >>> print(*[1], *[2], 3, *[4, 5])
1 2 3 4 5 1 2 3 4 5
...@@ -333,7 +333,7 @@ to use an arbitrary number of unpackings in function calls:: ...@@ -333,7 +333,7 @@ to use an arbitrary number of unpackings in function calls::
1 2 3 4 1 2 3 4
Similarly, tuple, list, set, and dictionary displays allow multiple Similarly, tuple, list, set, and dictionary displays allow multiple
unpackings:: unpackings (see :ref:`exprlists` and :ref:`dict`)::
>>> *range(4), 4 >>> *range(4), 4
(0, 1, 2, 3, 4) (0, 1, 2, 3, 4)
......
...@@ -591,6 +591,8 @@ IDLE ...@@ -591,6 +591,8 @@ IDLE
Documentation Documentation
------------- -------------
- Issue #24136: Document the new PEP 448 unpacking syntax of 3.5.
- Issue #26736: Used HTTPS for external links in the documentation if possible. - Issue #26736: Used HTTPS for external links in the documentation if possible.
- Issue #6953: Rework the Readline module documentation to group related - Issue #6953: Rework the Readline module documentation to group related
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment