2007-08-15 11:28:22 -03:00
|
|
|
:mod:`token` --- Constants used with Python parse trees
|
|
|
|
=======================================================
|
|
|
|
|
|
|
|
.. module:: token
|
|
|
|
:synopsis: Constants representing terminal nodes of the parse tree.
|
2016-06-11 16:02:54 -03:00
|
|
|
|
2007-08-15 11:28:22 -03:00
|
|
|
.. sectionauthor:: Fred L. Drake, Jr. <fdrake@acm.org>
|
|
|
|
|
2011-01-26 21:20:32 -04:00
|
|
|
**Source code:** :source:`Lib/token.py`
|
|
|
|
|
|
|
|
--------------
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
This module provides constants which represent the numeric values of leaf nodes
|
2020-07-26 12:27:52 -03:00
|
|
|
of the parse tree (terminal tokens). Refer to the file :file:`Grammar/Tokens`
|
2007-08-15 11:28:22 -03:00
|
|
|
in the Python distribution for the definitions of the names in the context of
|
|
|
|
the language grammar. The specific numeric values which the names map to may
|
|
|
|
change between Python versions.
|
|
|
|
|
2010-10-17 06:46:11 -03:00
|
|
|
The module also provides a mapping from numeric codes to names and some
|
|
|
|
functions. The functions mirror definitions in the Python C header files.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
.. data:: tok_name
|
|
|
|
|
|
|
|
Dictionary mapping the numeric values of the constants defined in this module
|
|
|
|
back to name strings, allowing more human-readable representation of parse trees
|
|
|
|
to be generated.
|
|
|
|
|
|
|
|
|
|
|
|
.. function:: ISTERMINAL(x)
|
|
|
|
|
2019-11-12 10:57:03 -04:00
|
|
|
Return ``True`` for terminal token values.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
.. function:: ISNONTERMINAL(x)
|
|
|
|
|
2019-11-12 10:57:03 -04:00
|
|
|
Return ``True`` for non-terminal token values.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
.. function:: ISEOF(x)
|
|
|
|
|
2019-11-12 10:57:03 -04:00
|
|
|
Return ``True`` if *x* is the marker indicating the end of input.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
|
2010-10-17 06:46:11 -03:00
|
|
|
The token constants are:
|
|
|
|
|
2018-12-22 05:18:40 -04:00
|
|
|
.. include:: token-list.inc
|
2017-05-31 11:00:21 -03:00
|
|
|
|
2017-06-06 12:43:35 -03:00
|
|
|
The following token type values aren't used by the C tokenizer but are needed for
|
|
|
|
the :mod:`tokenize` module.
|
|
|
|
|
|
|
|
.. data:: COMMENT
|
2023-05-20 21:03:02 -03:00
|
|
|
:noindex:
|
2017-06-06 12:43:35 -03:00
|
|
|
|
|
|
|
Token value used to indicate a comment.
|
|
|
|
|
|
|
|
|
|
|
|
.. data:: NL
|
2023-05-20 21:03:02 -03:00
|
|
|
:noindex:
|
2017-06-06 12:43:35 -03:00
|
|
|
|
|
|
|
Token value used to indicate a non-terminating newline. The
|
|
|
|
:data:`NEWLINE` token indicates the end of a logical line of Python code;
|
|
|
|
``NL`` tokens are generated when a logical line of code is continued over
|
|
|
|
multiple physical lines.
|
|
|
|
|
|
|
|
|
|
|
|
.. data:: ENCODING
|
|
|
|
|
|
|
|
Token value that indicates the encoding used to decode the source bytes
|
|
|
|
into text. The first token returned by :func:`tokenize.tokenize` will
|
|
|
|
always be an ``ENCODING`` token.
|
|
|
|
|
|
|
|
|
2019-01-31 07:40:27 -04:00
|
|
|
.. data:: TYPE_COMMENT
|
2020-08-13 16:41:54 -03:00
|
|
|
:noindex:
|
2019-01-31 07:40:27 -04:00
|
|
|
|
|
|
|
Token value indicating that a type comment was recognized. Such
|
|
|
|
tokens are only produced when :func:`ast.parse()` is invoked with
|
|
|
|
``type_comments=True``.
|
|
|
|
|
|
|
|
|
2017-06-06 12:43:35 -03:00
|
|
|
.. versionchanged:: 3.5
|
2023-07-26 12:34:15 -03:00
|
|
|
Added :data:`!AWAIT` and :data:`!ASYNC` tokens.
|
2017-06-06 12:43:35 -03:00
|
|
|
|
|
|
|
.. versionchanged:: 3.7
|
|
|
|
Added :data:`COMMENT`, :data:`NL` and :data:`ENCODING` tokens.
|
2017-10-06 00:24:46 -03:00
|
|
|
|
|
|
|
.. versionchanged:: 3.7
|
2023-07-26 12:34:15 -03:00
|
|
|
Removed :data:`!AWAIT` and :data:`!ASYNC` tokens. "async" and "await" are
|
2017-10-06 00:24:46 -03:00
|
|
|
now tokenized as :data:`NAME` tokens.
|
2019-01-31 07:40:27 -04:00
|
|
|
|
|
|
|
.. versionchanged:: 3.8
|
2020-02-28 19:25:36 -04:00
|
|
|
Added :data:`TYPE_COMMENT`, :data:`TYPE_IGNORE`, :data:`COLONEQUAL`.
|
2023-07-26 12:34:15 -03:00
|
|
|
Added :data:`!AWAIT` and :data:`!ASYNC` tokens back (they're needed
|
2019-03-07 16:38:08 -04:00
|
|
|
to support parsing older Python versions for :func:`ast.parse` with
|
|
|
|
``feature_version`` set to 6 or lower).
|
2023-07-26 12:34:15 -03:00
|
|
|
|
|
|
|
.. versionchanged:: 3.13
|
|
|
|
Removed :data:`!AWAIT` and :data:`!ASYNC` tokens again.
|
|
|
|
|