U ��,aw � @ s0 d Z dZdddddddd d ddd dddddgZddlZddlZddlZddl Z ddlmZm Z dZdZdZdZdZdZdZG dd� de�Zdd � ZG d!d� de�ZG d"d� de�ZG d#d � d e�ZG d$d� de�ZG d%d � d e�Zd&d'� ZG d(d� de�ZG d)d� de�Z G d*d� de�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 dAd� de�Z-G dBd� de�Z.G dCdD� dDe�Z/G dEdF� dFe/�Z0G dGdH� dHe0�Z1G dId� dee/�Z2dS )Ja� 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�FileType� HelpFormatter�ArgumentDefaultsHelpFormatter�RawDescriptionHelpFormatter�RawTextHelpFormatter�MetavarTypeHelpFormatter� Namespace�Action�ONE_OR_MORE�OPTIONAL�PARSER� REMAINDER�SUPPRESS�ZERO_OR_MORE� N)�gettext�ngettextz==SUPPRESS==�?�*�+zA...�...Z_unrecognized_argsc @ s( 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 ],\}}|�� rZ|�d||f � q6|||<