File: //usr/lib/python3.10/__pycache__/ast.cpython-310.pyc
o
    E�h��  �                   @   s�  d Z ddlZddlT ddlmZmZ ddlmZmZ d`ddd	�d
d�Z	dd
� Z
dadd�dd�Zdd� Zdd� Z
dbdd�Zdd� Zdd� Zdcdd�Zdd � Zd!d"� Zdd#�d$d%�Zd&d'� ZG d(d)� d)e�ZG d*d+� d+e�Zeed,�s�d-d.� Zd/d0� Zeee�e_eee�e_G d1d2� d2e �Z!d3d4� Z"G d5d6� d6ee!d7�Z#G d8d9� d9ee!d7�Z$G d:d;� d;ee!d7�Z%G d<d=� d=ee!d7�Z&G d>d?� d?ee!d7�Z'e#e(e)e*fe$e+fe%e,fe&e d�e-fe'e d@�fiZ.e#e-fiZ/e-d=e d�d=e(d6e)d6e*d6e+d9e,d;e d@�d?iZ0G dAdB� dBe1�Z2G dCdD� dDe2�Z3G dEdF� dFe2�Z4ee5dG��s"dHdI� Z6dJdK� Z7ee6e7�e5_8G dLdM� dMe9�Z:G dNdO� dOe;�Z<G dPdQ� dQe;�Z=G dRdS� dSe;�Z>dTe?ej@jAd � ZBG dUdV� dVe�ZCdWZDdXZEg eD�eE�R ZFG dYdZ� dZe�ZGd[d\� ZHd]d^� ZIeJd_k�ryeI�  dS dS )daH  
    ast
    ~~~
    The `ast` module helps Python applications to process trees of the Python
    abstract syntax grammar.  The abstract syntax itself might change with
    each Python release; this module helps to find out programmatically what
    the current grammar looks like and allows modifications of it.
    An abstract syntax tree can be generated by passing `ast.PyCF_ONLY_AST` as
    a flag to the `compile()` builtin function or by using the `parse()`
    function from this module.  The result will be a tree of objects whose
    classes all inherit from `ast.AST`.
    A modified abstract syntax tree can be compiled into a Python code object
    using the built-in `compile()` function.
    Additionally various helper functions are provided that make working with
    the trees simpler.  The main intention of the helper functions and this
    module in general is to provide an easy to use interface for libraries
    that work tightly with the python syntax (template engines for example).
    :copyright: Copyright 2008 by Armin Ronacher.
    :license: Python License.
�    N)�*)�contextmanager�nullcontext)�IntEnum�auto�	<unknown>�execF)�
type_comments�feature_versionc                C   sR   t }|r|tO }t|t�r|\}}|dksJ �|}n|du r d}t| ||||d�S )z�
    Parse the source into an AST node.
    Equivalent to compile(source, filename, mode, PyCF_ONLY_AST).
    Pass type_comments=True to get back type comments where the syntax allows.
    �   N���)�_feature_version)�
PyCF_ONLY_AST�PyCF_TYPE_COMMENTS�
isinstance�tuple�compile)�source�filename�moder	   r
   �flags�major�minor� r   �/usr/lib/python3.10/ast.py�parse!   s   
�r   c                    sf   t | t�rt| �d�dd�} t | t�r| j} dd� ��fdd���fdd	��� ���fd
d�� � | �S )aT  
    Evaluate an expression node or a string containing only a Python
    expression.  The string or node provided may only consist of the following
    Python literal structures: strings, bytes, numbers, tuples, lists, dicts,
    sets, booleans, and None.
    Caution: A complex expression can overflow the C stack and cause a crash.
    z 	�eval�r   c                 S   s4   d}t | dd � }r|d|� �7 }t|d| �� ��)Nzmalformed node or string�linenoz	 on line �: )�getattr�
ValueError)�node�msg�lnor   r   r   �_raise_malformed_nodeC   s   z+literal_eval.<locals>._raise_malformed_nodec                    s,   t | t�rt| j�tttfvr� | � | jS �N)r   �Constant�type�value�int�float�complex�r"