U ��,axE � @ s� d Z ddlZddlZddlZddlZddlT dZe�de �Ze�deef �Z e �dd�ZG d d � d �Z dd� Zd d� ejD �Zdd� Zdd� ZG dd� d�Zedkr�dZdD ]*Zede � ed�eee��� e� q�dS )a6 distutils.fancy_getopt Wrapper around the standard getopt module that provides the following additional features: * short and long options are tied together * options have help strings, so fancy_getopt could potentially create a complete usage summary * options set attributes of a passed-in object � N)�*z[a-zA-Z](?:[a-zA-Z0-9-]*)z^%s$z^(%s)=!(%s)$�-�_c @ s� e Zd ZdZddd�Zdd� Zdd� Zd d d �Zdd� Zd d� Z dd� Z dd� Zdd� Zdd� Z d!dd�Zdd� Zd"dd�Zd#dd�ZdS )$�FancyGetopta� Wrapper around the standard 'getopt()' module that provides some handy extra functionality: * short and long options are tied together * options have help strings, and help text can be assembled from them * options set attributes of a passed-in object * boolean options can have "negative aliases" -- eg. if --quiet is the "negative alias" of --verbose, then "--quiet" on the command line sets 'verbose' to false Nc C sN || _ i | _| j r| �� i | _i | _g | _g | _i | _i | _i | _ g | _ d S �N)�option_table�option_index�_build_index�alias�negative_alias� short_opts� long_opts� short2long� attr_name� takes_arg�option_order��selfr � r �;/opt/alt/python38/lib64/python3.8/distutils/fancy_getopt.py�__init__) s zFancyGetopt.__init__c C s( | j �� | jD ]}|| j |d <