PEP 622: Change 'target' to 'subject' (#1498)
This commit is contained in:
parent
561593f1ff
commit
b893d2e02b
21
pep-0622.rst
21
pep-0622.rst
|
@ -169,6 +169,9 @@ The proposed indentation structure is as following::
|
||||||
case pattern_2:
|
case pattern_2:
|
||||||
...
|
...
|
||||||
|
|
||||||
|
Here, `some_expression` represents the value that is being matched against,
|
||||||
|
which will be referred to hereafter as the *subject* of the match.
|
||||||
|
|
||||||
|
|
||||||
Match semantics
|
Match semantics
|
||||||
---------------
|
---------------
|
||||||
|
@ -360,7 +363,7 @@ remaining items::
|
||||||
case (1, x):
|
case (1, x):
|
||||||
print(f"Got 1 and {x}")
|
print(f"Got 1 and {x}")
|
||||||
|
|
||||||
To match a sequence pattern the target must be an instance of
|
To match a sequence pattern the subject must be an instance of
|
||||||
``collections.abc.Sequence``, and it cannot be any kind of string
|
``collections.abc.Sequence``, and it cannot be any kind of string
|
||||||
(``str``, ``bytes``, ``bytearray``). It cannot be an iterator. For matching
|
(``str``, ``bytes``, ``bytearray``). It cannot be an iterator. For matching
|
||||||
on a specific collection class, see class pattern below.
|
on a specific collection class, see class pattern below.
|
||||||
|
@ -393,8 +396,8 @@ patterns are allowed in key positions::
|
||||||
case {constants.DEFAULT_PORT: sub_config, **rest}:
|
case {constants.DEFAULT_PORT: sub_config, **rest}:
|
||||||
process_config(sub_config, rest)
|
process_config(sub_config, rest)
|
||||||
|
|
||||||
The target must be an instance of ``collections.abc.Mapping``.
|
The subject must be an instance of ``collections.abc.Mapping``.
|
||||||
Extra keys in the target are ignored even if ``**rest`` is not present.
|
Extra keys in the subject are ignored even if ``**rest`` is not present.
|
||||||
This is different from sequence pattern, where extra items will cause a
|
This is different from sequence pattern, where extra items will cause a
|
||||||
match to fail. But mappings are actually different from sequences: they
|
match to fail. But mappings are actually different from sequences: they
|
||||||
have natural structural sub-typing behavior, i.e., passing a dictionary
|
have natural structural sub-typing behavior, i.e., passing a dictionary
|
||||||
|
@ -428,7 +431,7 @@ example::
|
||||||
...
|
...
|
||||||
|
|
||||||
Whether a match succeeds or not is determined by the equivalent of an
|
Whether a match succeeds or not is determined by the equivalent of an
|
||||||
``isinstance`` call. If the target (``shape``, in the example) is not
|
``isinstance`` call. If the subject (``shape``, in the example) is not
|
||||||
an instance of the named class (``Point`` or ``Rectangle``), the match
|
an instance of the named class (``Point`` or ``Rectangle``), the match
|
||||||
fails. Otherwise, it continues (see details in the `runtime`_
|
fails. Otherwise, it continues (see details in the `runtime`_
|
||||||
section).
|
section).
|
||||||
|
@ -591,7 +594,7 @@ The procedure is as following:
|
||||||
refuse the temptation to guess."
|
refuse the temptation to guess."
|
||||||
|
|
||||||
* If there are any match-by-keyword items the keywords are looked up
|
* If there are any match-by-keyword items the keywords are looked up
|
||||||
as attributes on the target. If the lookup succeeds the value is
|
as attributes on the subject. If the lookup succeeds the value is
|
||||||
matched against the corresponding sub-pattern. If the lookup fails,
|
matched against the corresponding sub-pattern. If the lookup fails,
|
||||||
the match fails.
|
the match fails.
|
||||||
|
|
||||||
|
@ -603,7 +606,7 @@ For the most commonly-matched built-in types (``bool``,
|
||||||
``frozenset``, ``int``, ``list``, ``set``, ``str``, and ``tuple``), a
|
``frozenset``, ``int``, ``list``, ``set``, ``str``, and ``tuple``), a
|
||||||
single positional sub-pattern is allowed to be passed to
|
single positional sub-pattern is allowed to be passed to
|
||||||
the call. Rather than being matched against any particular attribute
|
the call. Rather than being matched against any particular attribute
|
||||||
on the target, it is instead matched against the target itself. This
|
on the subject, it is instead matched against the subject itself. This
|
||||||
creates behavior that is useful and intuitive for these objects:
|
creates behavior that is useful and intuitive for these objects:
|
||||||
|
|
||||||
* ``bool(False)`` matches ``False`` (but not ``0``).
|
* ``bool(False)`` matches ``False`` (but not ``0``).
|
||||||
|
@ -1655,11 +1658,11 @@ These customized match behaviors would be controlled by a special
|
||||||
``__match__`` method on the class name. There were two competing variants:
|
``__match__`` method on the class name. There were two competing variants:
|
||||||
|
|
||||||
* A 'full-featured' match protocol which would pass in not only
|
* A 'full-featured' match protocol which would pass in not only
|
||||||
the target object to be matched, but detailed information about
|
the subject to be matched, but detailed information about
|
||||||
which attributes the specified pattern was interested in.
|
which attributes the specified pattern was interested in.
|
||||||
* A simplified match protocol, which only passed in the target object,
|
* A simplified match protocol, which only passed in the subject value,
|
||||||
and which returned a "proxy object" (which in most cases could be
|
and which returned a "proxy object" (which in most cases could be
|
||||||
just the target) containing the matchable attributes.
|
just the subject) containing the matchable attributes.
|
||||||
|
|
||||||
Here's an example of one version of the more complex protocol proposed::
|
Here's an example of one version of the more complex protocol proposed::
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue