From: Ville Skyttä Date: Sun, 5 Aug 2018 16:38:04 +0000 (+0300) Subject: bpo-34336: Don't promote possibility to leave out typing.Optional (#8677) X-Git-Tag: v3.8.0a1~1241 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=336c945858055059a65134d4c501a85037d70d99;p=thirdparty%2FPython%2Fcpython.git bpo-34336: Don't promote possibility to leave out typing.Optional (#8677) --- diff --git a/Doc/library/typing.rst b/Doc/library/typing.rst index 91d10e324cae..23a64156c592 100644 --- a/Doc/library/typing.rst +++ b/Doc/library/typing.rst @@ -990,10 +990,18 @@ The module defines the following classes, functions and decorators: Note that this is not the same concept as an optional argument, which is one that has a default. An optional argument with a - default needn't use the ``Optional`` qualifier on its type - annotation (although it is inferred if the default is ``None``). - A mandatory argument may still have an ``Optional`` type if an - explicit value of ``None`` is allowed. + default does not require the ``Optional`` qualifier on its type + annotation just because it is optional. For example:: + + def foo(arg: int = 0) -> None: + ... + + On the other hand, if an explicit value of ``None`` is allowed, the + use of ``Optional`` is appropriate, whether the argument is optional + or not. For example:: + + def foo(arg: Optional[int] = None) -> None: + ... .. data:: Tuple