File: //usr/lib/python3.10/__pycache__/argparse.cpython-310.pyc
o
    E�h� �                   @   sB  d Z dZg d�ZddlZddlZddlZz
ddl	m	Z
mZ W n ey/   dd� Z
dd	� ZY nw d
Z
dZdZd
ZdZdZdZG dd� de�Zdd� ZG dd� de�ZG dd� de�ZG dd� de�ZG dd� de�ZG dd� de�Zdd � ZG d!d"� d"e�ZG d#d$� d$e�ZG d%d&� d&e�Z G d'd(� d(e �Z!G d)d*� d*e �Z"G d+d,� d,e �Z#G d-d.� d.e#�Z$G d/d0� d0e#�Z%G d1d2� d2e �Z&G d3d4� d4e �Z'G d5d6� d6e �Z(G d7d8� d8e �Z)G d9d:� d:e �Z*G d;d<� d<e �Z+G d=d>� d>e&�Z,G d?d@� d@e�Z-G dAdB� dBe�Z.G dCdD� dDe�Z/G dEdF� dFe/�Z0G dGdH� dHe0�Z1G dIdJ� dJee/�Z2dS )Ka�
  Command-line parsing library
This module is an optparse-inspired command-line parsing library that:
    - handles both optional and positional arguments
    - produces highly informative usage messages
    - supports parsers that dispatch to sub-parsers
The following is a simple usage example that sums integers from the
command-line and writes the result to a file::
    parser = argparse.ArgumentParser(
        description='sum the integers at the command line')
    parser.add_argument(
        'integers', metavar='int', nargs='+', type=int,
        help='an integer to be summed')
    parser.add_argument(
        '--log', default=sys.stdout, type=argparse.FileType('w'),
        help='the file where the sum should be written')
    args = parser.parse_args()
    args.log.write('%s' % sum(args.integers))
    args.log.close()
The module contains the following public classes:
    - ArgumentParser -- The main entry point for command-line parsing. As the
        example above shows, the add_argument() method is used to populate
        the parser with actions for optional and positional arguments. Then
        the parse_args() method is invoked to convert the args at the
        command-line into an object with attributes.
    - ArgumentError -- The exception raised by ArgumentParser objects when
        there are errors with the parser's actions. Errors raised while
        parsing the command-line are caught by ArgumentParser and emitted
        as command-line messages.
    - FileType -- A factory for defining types of files to be created. As the
        example above shows, instances of FileType are typically passed as
        the type= argument of add_argument() calls.
    - Action -- The base class for parser actions. Typically actions are
        selected by passing strings like 'store_true' or 'append_const' to
        the action= argument of add_argument(). However, for greater
        customization of ArgumentParser actions, subclasses of Action may
        be defined and passed as the action= argument.
    - HelpFormatter, RawDescriptionHelpFormatter, RawTextHelpFormatter,
        ArgumentDefaultsHelpFormatter -- Formatter classes which
        may be passed as the formatter_class= argument to the
        ArgumentParser constructor. HelpFormatter is the default,
        RawDescriptionHelpFormatter and RawTextHelpFormatter tell the parser
        not to change the formatting for help text, and
        ArgumentDefaultsHelpFormatter adds information about argument defaults
        to the help.
All other classes in this module are considered implementation details.
(Also note that HelpFormatter and RawDescriptionHelpFormatter are only
considered public as object names -- the API of the formatter objects is
still considered an implementation detail.)
z1.1)�ArgumentParser�
ArgumentError�ArgumentTypeError�BooleanOptionalAction�FileType�
HelpFormatter�ArgumentDefaultsHelpFormatter�RawDescriptionHelpFormatter�RawTextHelpFormatter�MetavarTypeHelpFormatter�	Namespace�Action�ONE_OR_MORE�OPTIONAL�PARSER�	REMAINDER�SUPPRESS�ZERO_OR_MORE�    N)�gettext�ngettextc                 C   �   | S �N� )�messager   r   �/usr/lib/python3.10/argparse.py�__   �   r   c                 C   s   |dkr| S |S �N�   r   )�singular�plural�nr   r   r   r   a   s   r   z==SUPPRESS==�?�*�+zA...�...�_unrecognized_argsc                   @   �(   e Zd ZdZdd� Zdd� Zdd� ZdS )	�_AttributeHoldera  Abstract base class that provides __repr__.
    The __repr__ method returns a string in the format::
        ClassName(attr=name, attr=name, ...)
    The attributes are determined either by a class-level attribute,
    '_kwarg_names', or by inspecting the instance __dict__.
    c                 C   s�   t | �j}g }i }| �� D ]	}|�t|�� q
| �� D ]\}}|�� r-|�d||f � q|||<