U
    *b4                     @   s\   d dl mZ d dlmZmZmZmZ dd ZG dd dZG dd deZ	G d	d
 d
Z
dS )    )Action)ConfigParserParsingErrorErrorDuplicateOptionErrorc                 C   s   t | }|tkp|tkS )z@Return true if val is an instance of a known sequence type.
    )typelisttuple)valZval_type r   -/usr/lib/python3/dist-packages/sos/options.py_is_seq   s    r   c                   @   s   e Zd Zdd Zdd Zd dd	Zd
d Zdd Zi fddZe	i fddZ
e	dd Zdd Zdd Zd!ddZd"ddZdd ZdS )#
SoSOptionsc                 C   s   dd }t ||rt||}t| |}||r6||rL|sL|| jkrxt|sxt| || |rj| j| q| j| nt|rt| |||  d S )Nc                 S   s   | dkp| d kS )N r   )r
   r   r   r   _unset   s    z%SoSOptions._merge_opt.<locals>._unset)hasattrgetattr_nondefaultr   setattrdiscardadd)selfoptsrc
is_defaultr   ZnewvalueZoldvaluer   r   r   
_merge_opt   s"    


zSoSOptions._merge_optc                 C   s0   t |tst|}| jD ]}| ||| qd S N)
isinstancedictvars	arg_namesr   )r   r   r   argr   r   r   _merge_opts/   s    

zSoSOptions._merge_optsF r   c           	         sz   |}d} j D ]}||| | 7 }q||  fdd j D }|sVdd |D }ndd |D }|t| || S )aI  Format a SoSOptions object as a human or machine readable string.

            :param quote: quote option values
            :param sep: list separator string
            :param prefix: arbitrary prefix string
            :param suffix: arbitrary suffix string
            :param literal: print values as Python literals
        z=%sc                    s   g | ]}t  |qS r   )r   ).0r!   r   r   r   
<listcomp>D   s     z$SoSOptions.__str.<locals>.<listcomp>c                 S   s"   g | ]}t |rd |n|qS ),)r   joinr$   vr   r   r   r&   G   s     c                 S   s"   g | ]}t |trd | n|qS )z'%s')r   strr)   r   r   r   r&   J   s     )r    stripr	   )	r   quotesepprefixsuffixargsZarg_fmtr!   Zvalsr   r%   r   Z__str5   s    	

zSoSOptions.__strc                 C   s   |   S r   _SoSOptions__strr%   r   r   r   __str__N   s    zSoSOptions.__str__c                 C   s   | j dddddS )NTz, zSoSOptions())r-   r.   r/   r0   r2   r%   r   r   r   __repr__Q   s    
zSoSOptions.__repr__c                 K   sh   || _ t| | _t | _| j D ]}t| || j |  q"| D ] }| j| t| |||  qBdS )a  Initialise a new ``SoSOptions`` object from keyword arguments.

            Initialises the new object with values taken from keyword
            arguments matching the names of ``SoSOptions`` attributes.

            A ``ValueError`` is raised is any of the supplied keyword
            arguments does not correspond to a known ``SoSOptions`
            attribute name.

            :param *kwargs: a list of ``SoSOptions`` keyword args.
            :returns: the new ``SoSOptions`` object.
        N)arg_defaultsr   keysr    setr   r   append)r   r7   kwargsr!   r   r   r   __init__U   s    
zSoSOptions.__init__c                 C   s&   t f t|d|i}||d |S )a  Initialise a new SoSOptions object from a ``Namespace``
            obtained by parsing command line arguments.

            :param args: parsed command line arguments
            :returns: an initialised SoSOptions object
            :returntype: SoSOptions
        r7   T)r   r   r"   )clsr1   r7   Zoptsr   r   r   	from_argsm   s    	zSoSOptions.from_argsc                    sP   d}d} |krd  gS  |kr> fddt dt|D S d  d | gS )	zConvert a named option and optional value to command line
            argument notation, correctly handling options that take
            no value or that have special representations (e.g. verify
            and verbose).
        )Z
alloptionszallow-system-changeszall-logsZbatchZbuilddebugZexperimentalzlist-pluginszlist-presetszlist-profilesz	no-reportzno-env-varsquietZverify)verbose--%sc                    s   g | ]}d   qS )rB   r   )r$   dr   r   r   r&      s     z+SoSOptions._opt_to_args.<locals>.<listcomp>r   --=)rangeint)r=   r   r
   Zno_valuecountr   rD   r   _opt_to_argsz   s    
zSoSOptions._opt_to_argsc                 C   s   t | j| t|r|S t | j| tr<dd |dD S t | j| tr|| }|dkr`dS |dkrldS td||f t | j| trz
t|W S  t	k
r   td	||f Y nX |S )
a  Ensure that the value read from a config file is the proper type
        for consumption by the component, as defined by arg_defaults.

        Params:
            :param key:         The key in arg_defaults we need to match the
                                type of
            :param val:         The value to be converted to a particular type
            :param conf:        File values are being loaded from
        c                 S   s   g | ]}|qS r   r   r)   r   r   r   r&      s     z/SoSOptions._convert_to_type.<locals>.<listcomp>r'   )trueZonZyesT)ZfalseZoffZnoFz6Value of '%s' in %s must be True or False or analagousz#Value of '%s' in %s must be integer)
r   r7   r   r   splitboollower	ExceptionrH   
ValueError)r   keyr
   confZ_valr   r   r   _convert_to_type   s.    

zSoSOptions._convert_to_typec           
   
      sD   fdd}t  }zz"t }|| W 5 Q R X W nZ tk
rp } ztd|j|j f W 5 d}~X Y n$ ttfk
r   td  Y nX W n< t	t
fk
r } ztd |jd f  W 5 d}~X Y nX |d| ||| |d	r@td
r@|d	D ]4\}}	|dd jkr
j|d |	  q
dS )zRead the provided config_file and update options from that.

        Positional arguments:

            :param config_file:             Filepath to the config file
            :param component:               Which component (section) to load
        c                    s   | | rt|| }d| kr6t|d|d< dddd}t|D ]<}d|krl||||dd< ||krJ||||| < qJ| D ]\\}}t|t	r|d	kr|d
d}|j
krtd|| f  q|| }t|| qd S )NrA   	verbosityZlabelplugoptsZprofiles)nameZplugin_optionZprofile-_keywordsr#   r   z#Unknown option '%s' in section '%s')has_sectionr   itemsr8   rH   popr   replacer   r+   r7   printrS   r   )sectionconfigodictZrename_optsrQ   r
   config_filer   r   r   _update_from_section   s.    

z9SoSOptions.update_from_conf.<locals>._update_from_sectionz0Duplicate option '%s' in section '%s' in file %sNz%Failed to parse configuration file %sz2WARNING: Unable to read configuration file %s : %s   globalZplugin_optionsrU   .r   rF   )r   openZreadfpr   exitZoptionr_   r   r   OSErrorIOErrorr^   r1   rZ   r   r[   rL   Zskip_pluginsrU   r:   )
r   rc   Z	componentrd   r`   ferrerQ   r
   r   rb   r   update_from_conf   s4    	#


zSoSOptions.update_from_confTc                 C   s<   | j D ]0}t||sqt||dk	s(|s| ||d qdS )aN  Merge another set of ``SoSOptions`` into this object.

            Merge two ``SoSOptions`` objects by setting unset or default
            values to their value in the ``src`` object.

            :param src: the ``SoSOptions`` object to copy from
            :param is_default: ``True`` if new default values are to be set.
        NF)r    r   r   r   )r   r   Zskip_defaultr!   r   r   r   merge   s
    	

zSoSOptions.mergec                 C   s6   i }| j D ]&}t| |}|r(|dkr(d}|||< q
|S )zReturn this ``SoSOptions`` option values as a dictionary of
            argument name to value mappings.

            :returns: a name:value dictionary of option values.
        Z
add_presetZ
del_presetZdescZnoteN)r    r   )r   Zpreset_filterra   r!   valuer   r   r   r      s    


zSoSOptions.dictc                    sL   fddfdddd  t   dd d	} fd
d|D S )zReturn command arguments for this object.

            Return a list of the non-default options of this ``SoSOptions``
            object in ``sosreport`` command line argument notation:

                ``["--all-logs", "-vvv"]``

        c                    sL   d}|r||krdS | dkr$|r$dS |  j krHt|t j |  krHdS dS )z. Test for non-null option values.
            )FalseNonez[]z""z''0FrU   T)r7   r+   )rV   rr   Znull_valuesr%   r   r   	has_value  s    
z%SoSOptions.to_args.<locals>.has_valuec                    s*   | dkrdS | dkr |dkr dS  | |S )z8 Filter out preset and null-valued options.
            rq   F)Zlog_sizeZplugin_timeoutZcmd_timeoutr   Tr   )rV   rr   )rv   r   r   
filter_opt&  s    z&SoSOptions.to_args.<locals>.filter_optc                 S   sz   |  drdt|d  }|S | dd} t|r<d|n|}|dk	rVd| |f }n| }t|dkrnd	| nd| }|S )
zD Convert sos option notation to command line arguments.
            rT   rW   r*   rX   r'   Tz%s %sre   rE   )
startswithrH   r]   r   r(   len)rV   rr   r!   r   r   r   r   argify1  s    
z"SoSOptions.to_args.<locals>.argifyc                 S   s   | d S )Nr   r   )xr   r   r   <lambda>E      z$SoSOptions.to_args.<locals>.<lambda>)rQ   c                    s$   g | ]\}}||r ||qS r   r   )r$   nr*   )rz   rw   r   r   r&   F  s     
 z&SoSOptions.to_args.<locals>.<listcomp>)sortedr   r[   )r   Z	opt_itemsr   )rz   rw   rv   r   r   to_args  s
    	zSoSOptions.to_argsN)Fr#   r   r   )T)T)__name__
__module____qualname__r   r"   r3   r4   r6   r<   classmethodr>   rJ   rS   ro   rp   r   r   r   r   r   r   r      s   

 D

r   c                   @   s   e Zd ZdZdddZdS )SosListOptionz0Allow to specify comma delimited list of pluginsNc                 C   sB   dd | dD }t|| jr0|t|| j7 }t|| j| d S )Nc                 S   s   g | ]}|qS r   r   )r$   r   r   r   r   r&   N  s     z*SosListOption.__call__.<locals>.<listcomp>r'   )rL   r   destr   )r   parser	namespacevaluesZoption_stringr[   r   r   r   __call__M  s    zSosListOption.__call__)N)r   r   r   __doc__r   r   r   r   r   r   I  s   r   c                   @   s   e Zd ZdZdddZdS )ClusterOptionz6Used to store/manipulate options for cluster profiles.Nc                 C   s"   || _ || _|| _|| _|| _d S r   )rV   rr   opt_typeclusterdescription)r   rV   rr   r   r   r   r   r   r   r<   W  s
    zClusterOption.__init__)N)r   r   r   r   r<   r   r   r   r   r   T  s   r   N)argparser   configparserr   r   r   r   r   r   r   r   r   r   r   r   <module>	   s     6