????

Your IP : 3.149.237.146


Current Path : /lib64/python3.6/site-packages/pcp/__pycache__/
Upload File :
Current File : //lib64/python3.6/site-packages/pcp/__pycache__/pmconfig.cpython-36.opt-1.pyc

3

4>�f6��@s�dZddlmZddlmZyddlZWnek
rDddlZYnXddlZddl	Z	ddl
Z
ddlZddlZddl
Z
ddlZddlmZdZdZdZGd	d
�d
e�ZdS)z" PCP Python Utils Config Routines �)�deepcopy)�OrderedDictN)�pmapiZxxx�Fc@s�eZdZdZdd�Zdd�Zdd�Zdd	�Zd
d�Zdd
�Z	dd�Z
dd�Zdd�Zdd�Z
dd�Zdd�Zdd�Zdd�Zdd�Zd d!�Zd"d#�Zd$d%�Zd&d'�Zd\d*d+�Zd,d-�Zd.d/�Zd0d1�Zd)gfd2d3�Zd4d5�Zd6d7�Zd8d9�Zd:d;�ZGd<d=�d=e �Z!d>d?�Z"d@dA�Z#e$dBfdCdD�Z%dEdF�Z&dGdH�Z'e$dBfdIdJ�Z(dKdL�Z)dMdN�Z*dOdP�Z+dQdR�Z,dSdT�Z-dUdV�Z.d]dXdY�Z/d^dZd[�Z0d(S)_�pmConfigz Config reader and validator cCshd|_d|_||_g|_g|_g|_g|_g|_t�|_	d
|_
d|_g|_i|_
g|_t�|_g|_dS)N�-?�--help�-V�	--version�label�	instances�unit�type�width�	precision�limit�formular)rrr	r
)rrr
rrrrr)�arghelp�
metricspec�util�pmids�descs�insts�texts�labelsr�
res_labels�_round�_init_ts�_pred_indom�	_re_cache�_tmp�
_conf_metrics�_prev_insts)�selfr�r$� /usr/lib64/python3.6/pmconfig.py�__init__.s"zpmConfig.__init__csN�fdd�}x<dD]4}ytt|�}tj||�Wqtk
rDYqXqWdS)z Set default signal handler cs�jj�tjd�dS)z Default signal handler rN)r�finalize�sys�exit)Z_signumZ_frame)r#r$r%�handlerVs
z,pmConfig.set_signal_handler.<locals>.handler�SIGHUP�SIGTERMN)r+r,)�getattr�signal�	Exception)r#r*ZsigZsignumr$)r#r%�set_signal_handlerTs

zpmConfig.set_signal_handlercCs
|j|�S)z Set default config file )�set_config_path)r#�default_configr$r$r%�set_config_filebszpmConfig.set_config_filec	CsZd}tjjd�}tjjd�}xP|D]H}|jd|�}|jd|�}tj|tj�r"tjj	|�sdtjj
|�r"|}Pq"Wttj
dd��}x�|D]�}||jkr�dS|dks�|jd�r�y�|dkr�t|�}n|jdd	d�}tj|tj�p�tjj	|�p�tjj
|��r6tjj|��sd
}ntj|tj��s"d}nd}td
||f��Wq�tk
�rPPYq�Xq�W|S)z Set default config path N�~ZPCP_SYSCONF_DIRz$HOMEz$PCP_SYSCONF_DIRr�-c�--config�zNo such file or directoryzPermission deniedzNot a regular filez+Failed to read configuration from '%s':
%s.)r5r6)r5r6)�os�path�
expanduserrZ	pmContextZpmGetConfig�replace�access�R_OK�isfile�isdir�iterr(�argvr�
startswith�next�exists�IOError�
StopIteration)	r#r2�configZusrdirZsysdir�conf�args�arg�errr$r$r%r1fs<



zpmConfig.set_config_pathcCs�g}|jjr�tjj|jj�r,|j|jj�n\xZttj|jj��D]D}tjj|jj|�}|j	d�r@tj
|tj�r@tjj|�r@|j|�q@W|S)z' Helper to get individual config files z.conf)rrGr8r9r>�append�sorted�listdir�join�endswithr<r=)r#Z
conf_files�f�fnr$r$r%�_get_conf_files�s$zpmConfig._get_conf_filescCs�t|�}|dkr<|jd�r0|jd�r0|dd�}||j_dS|dkrHd}|dkrTd}|dkrh||j_�nP|dkr�|jd�dkr�||j_n|jdd�|j_�n|dkr�|jj	j
|�|jj	j�|j_n�|dk�r�|jj	j
|�|jj	j�|j_n�|dk�r|dk�rd|j_nd|j_n�|dk�r>|dk�r4d|j_nd|j_nz|dk�rX|jd�|j_n`yt|j|t|��WnHtk
�r�|jd��r�|jd��r�|dd�}t|j||�YnXdS)z Set options read from file �colxrow�"rN�true�True�y�yes�Yes�false�False�n�no�Nor�	speclocal�derived�;�,�samples�intervalr�raw�type_preferr���)rVrWrXrYrZ)r[r\r]r^r_rhrh)�strrBrPrrTr`�findrar;�optsZpmSetOptionSamples�pmGetOptionSamplesrd�pmSetOptionInterval�pmGetOptionIntervalrerrg�splitr�setattr�int�
ValueError)r#�name�valuer$r$r%�set_attr�sL










zpmConfig.set_attrcCs�|j|�sdSxv|j|�D]h}||jjkrH|j||�rHtd||f��||jjkrj|j||j||��q|dkrtd||f��qWdS)z0 Read options from a configuration file section Nz"No value set for option %s in [%s]�optionszUnknown option %s in [%s])�has_sectionrvr�keys�getrrru)r#rG�section�optr$r$r%�read_section_options�s
zpmConfig.read_section_optionscCsntjddkr&tjddkr&tj�}ntj�}t|_�x2|j�D�]$}yp|j|�d}|j||�xPt	tj
dd��D]:}|jd�rv|dd�|j�krv|dd�}|j||�qvWWq@tj
k
�r$}zNt|d�r�t|j�n|jdd}tjjd	||t|j�f�tjd�WYdd}~Xq@tk
�rd}z$tjjd
||f�tjd�WYdd}~Xq@Xq@WdS)z& Read options from configuration file r�r�rvN�:�linenoz4Failed to read configuration file '%s', line %s:
%s
z,Failed to read configuration file '%s':
%s.
)r(�version_info�ConfigParser�SafeConfigParserri�optionxformrS�readr|r@rArB�sections�Error�hasattrr��errors�stderr�write�messager)rr)r#rGrHrzrJ�errorr�r$r$r%�read_options�s*

"zpmConfig.read_optionscCs0tjjtjj�tjjtj�r&tj��tjj�S)z Read command line options )	r�c_apiZpmSetOptionFlagsZPM_OPTFLAG_DONEZpmGetOptionsFromListr(rA�
pmUsageErr�
pmGetOperands)r#r$r$r%�
read_cmd_line�szpmConfig.read_cmd_linecCstg}tj|g�}x^t|�dD]N}|jd�s6|jd�rB|dd�}|jd�sV|jd�rb|dd�}|j|�qW|S)z& Parse user-supplied instances string rrU�'rNrh)�csv�reader�listrBrPrL)r#rrr��instr$r$r%�parse_instances�szpmConfig.parse_instancescCs�g}|jd�dkr|d|fSd}|jd�d}|r\t|�dkr\|ddksX|ddkr\d}|jd�sp|jd�r�|jd�djd�d}|d}|d|j|�d�}|r�|j|dd
��}n
|j|�}|j|d	�}n
|r�|g}|jd�dkr�|d7}||fS)z" Parse instances from metric spec rcr~z,,rr�rUrNr7rh)�countro�len�	partition�rfindr�r;)r#�specrZquoted�sZinststr�qr$r$r%�parse_metric_spec_instancess((
z$pmConfig.parse_metric_spec_instancescCs^|g||<xNtdt|j��D]:}t||�|kr|dkrH||jg�q||jd�qWdS)z Parse new verbose metric rr~N)�ranger�rrL)r#�metrics�keyrt�indexr$r$r%�parse_new_verbose_metrics
z!pmConfig.parse_new_verbose_metriccCs�|jd�r |jd�r |dd�}|dkrx|jjdkrRd||dd||j_q�|jjd||dd|7_nD|jj|�dkr�|g|||jj|�d<n||||jj|�d<dS)	z& Parse additional verbose metric info rUrrNrbr�=rh)rBrPrrarr�)r#r�r�r�rtr$r$r%�parse_verbose_metric_info(s&z"pmConfig.parse_verbose_metric_infocCs�d}d|ks(d|kr,|jd�d|jkr,d}d|krRd|krR|jd�ddkrRd}|r�|j|d|�\}}|jd�||<|||d<n^d|ks�|jd�d|jkr�|j|||�n2|jd�\}}||kr�td|��|j||||�d	S)
z Parse metric information Frc�.rTrr~zUndeclared metric key %sN)�rsplitrr�ror�rrr�)r#r�r�rtZcompactr�rr$r$r%�parse_metric_info7s$"zpmConfig.parse_metric_infoc s@�jjj���s$tjjd�tj����fdd�}t�}t�}|�}t�}tj	ddkrxtj	ddkrxt
j
�}t
j
�}nt
j�}t
j�}t|_
t|_
�x\�j�D�]N}y|j|�Wnnt
jk
�r"}	zNt|	d�r�t|	j�n|	jdd}
tjjd	||
t|	j�f�tjd�WYd
d
}	~	XnX�jjdk�rp|jd��rpt�}x�|jd�D]�}|�jjk�r�tjjd�tjjd
|�tjd�|jd|��s�tjjd�tjjd||f�tjd�y�j|||jd|��WnVtk
�r0}	z8tjjd�tjjdt|	�|d�tjd�WYd
d
}	~	XnX�qPWx6|D].}
||
d
d�d}||
dd
�||<�q>Wx~|j�D]r}|j|��r�|j|�|j|�|||<x.|j |�D] \}}|j!|||j"dd���q�W|dk�rz|j|��qzWq�W�xP|D�]F}||d
k�r�|j|��r�t�}x�|j|�D]�}|j||��st||}tjjd�tjjd|||f�tjd�|�jjk�r.y�j|||j||��Wn^tk
�r�}	z@||}tjjd�tjjd|t|	�d�tjd�WYd
d
}	~	XnX�q.Wx6|D].}
||
d
d�d}||
dd
�||<�qW|||<�q�Wx6|D].}||d
k�rNtjjd|�tjd��qNW�jjdk�r�x|D]}
||
�jj#|
<�q�Wx^|D]V}
t$||
t%��r�||
�jj#|
<n.||
�r�x"||
D]}||�jj#|<�q�W�q�W�jj#�s.tjjd�tjd�t&�jj#��_'d
S)z! Construct and prepare metricset zNo metrics specified.
csht�}x\�D]T}|jd�r,d||dd�<q�j|�\}}|jd�}||d<|dd�||d<qW|S)z# Helper to read command line items rNrrcr~r)rrBr�ro)Ztempmet�metricr�r�m)r�r#r$r%�read_cmd_line_itemsXs


z5pmConfig.prepare_metrics.<locals>.read_cmd_line_itemsrr}rr~r�z4Failed to read configuration file '%s', line %s:
%s
N�globalz"Failed to read configuration file z)'%s':
Section [global] contains options.
z''%s':
No value set for %s in [global].
z'%s':
z.
�%z%%rvz#'%s':
No value set for %s in [%s].
z&Metricset definition ':%s' not found.
)rvr�)(rrkr�r(r�r�rr�rr�r�r�rir�rSr�r�r�r�r�r�r)�globalsrwrvrxryr�rrr�Zremove_sectionZadd_section�items�setr;r��
isinstancer�rr!)r#r�ZglobmetZconfmetZcmdlmetZsourcesrGZall_setsrHr�r�Zparsemetr�r�rsrzrtr�r�r$)r�r#r%�prepare_metricsQs�
"

"




"






zpmConfig.prepare_metricscCst|jd�r|jjrdSdS)z Check if help texts requested �
include_textsTF)r�rr�)r#r$r$r%�
provide_texts�szpmConfig.provide_textscCst|jd�r|jjrdSdS)z Check if labels needed �include_labelsTF)r�rr�)r#r$r$r%�provide_labels�szpmConfig.provide_labelscCsHg}x>|j�D]2\}}t|t�r2|j|j|��q|j||f�qW|S)z  Helper to flatten dict to list )r�r��dict�extend�_dict_to_flat_listrL)r#�dr��k�vr$r$r%r��s
zpmConfig._dict_to_flat_listcCs|j�}|j|�|S)z Helper to merge label dicts )�copy�update)r#Zd1Zd2Zd3r$r$r%�merge_labels�s
zpmConfig.merge_labelsNTc	Cs�|r|j|}n|jt|jjj��j|�}|dtjj	fkrF|d}n`|rh||dkrZin
|d|}n|dstin
|d|}|s�|}|s�dSn|d}|j
||�}ddjdd�|j|�D��d	S)
z Return labels as string Nrrz{}�{rccss|]\}}d||fVqdS)z	'%s':'%s'Nr$)�.0r�r�r$r$r%�	<genexpr>sz*pmConfig.get_labels_str.<locals>.<genexpr>�})
rrr�rr�rxr�rr��
PM_IN_NULLr�rOr�)	r#r�r��currZcombine�refr�inst_labels�
metric_labelsr$r$r%�get_labels_str�s
zpmConfig.get_labels_strcCst|jd�r|jjrdSdS)z Check if doing live filtering �live_filterTF)r�rr�)r#r$r$r%�do_live_filteringszpmConfig.do_live_filteringcCst|jd�r|jjrdSdS)z! Check if doing invert filtering �
invert_filterTF)r�rr�)r#r$r$r%�do_invert_filteringszpmConfig.do_invert_filteringcCs.|jjjtjjkr |jjj|�S|jjj|�S)z  Get instance domain for metric )r�contextrrr�ZPM_CONTEXT_ARCHIVEZpmGetInDomArchiveZ
pmGetInDom)r#�descr$r$r%�get_metric_indomszpmConfig.get_metric_indomcCsh|tjjkr|riSgS|r*|jjj|�Sg}|jjj|�}x&|D]}|j||krZ||ni�qBW|S)z Get instance labels )rr��
PM_INDOM_NULLrr�ZpmGetInstancesLabelsrL)r#�indomr�rr�Zindom_labels�ir$r$r%�get_inst_labelss
zpmConfig.get_inst_labelscCsT|jd�r|dd�}n8|jd�r.|dd�}|jd�rD|dd�}tjj|�}|S)z Get process basename �(r�-Nrrhrh)rBrPr8r9�basename)r#�procr$r$r%�get_proc_basename s


zpmConfig.get_proc_basenamecCs��y|jjj|�d}||jkr$dS|jjj|�d}|jjtjj	krXtjj
gdgf}n"|j|�}|dsztjj
gdgf}|jjtjj
kp�|jjtjjkp�|jjtjjkp�|jjtjjkp�|jjtjjkp�|jjtjjkp�|jjtjjks�tjtjj��|j�s|jjn|j}t|jd��r:|jj�r:|dd�r:dS|�r�|dd�r�|j��r�ggg}�x(|D�]}d}�y�|j��rd}	|ddj�dj��rxtt|d�D]d\}
}|j�d}|j��r�t|�t|�k�r�|dj|d|
�|dj|d|
�d}P�q�W|j dd	�j d
d	�j dd	�j!��r�d}	d
|ddk�r�|ddj�dj��r�xbt|d�D]R\}
}||j"|j�d�k�rv|dj|d|
�|dj|d|
�d}�qvW|�s@d}	t#j$d|d�}
xTt|d�D]D\}
}t#j%|
|��r�|dj|d|
�|dj|d|
��q�W~
WnDt&k
�r�}z&t'j(j)d|	||f�t'j*d�WYdd}~XnX�qjW|d�s�dSt+|�}|jj|�|j,j|�|j-j|�|j.��r�d\}}}}yf|jjj/|tjj0�}|jjj/|tjj1�}|jjtjj	k�rB|jjj2|tjj0�}|jjj2|tjj1�}Wn<tjk
�r�}z|j3dtjj4k�rp�WYdd}~XnX|j5j||||g�i}g}i}|j6��r�y6|jjj7|�}|j8|jjd|d�}|j8|jj�}Wnt&k
�r�YnX|j9j||g�||g|j:|<Wndtjk
�r~}zDt|jd��rL|jj;�rLdSt'j(j)d|t<|�f�t'j*d�WYdd}~XnXdS)z0 Validate individual metric and get its details rN�	omit_flatrFzInvalid instanceTr�r7�_r�zInvalid process� z
Invalid regexz\Az\Zz
%s '%s': %s.
�ignore_incompatzInvalid metric %s (%s).
)NNNN)=rr��pmLookupNamerZ
pmLookupDescs�contentsr�rr�r�r�r�rZ
PM_TYPE_32ZPM_TYPE_U32Z
PM_TYPE_64ZPM_TYPE_U64Z
PM_TYPE_FLOAT�PM_TYPE_DOUBLE�PM_TYPE_STRING�pmErrZPM_ERR_TYPEr rr�r�r��isdigitro�	enumeraterqrLr;�isalnumr��re�compile�matchr/r(r�r�r)�tuplerrr�ZpmLookupTextZPM_TEXT_ONELINEZPM_TEXT_HELPZpmLookupInDomTextrIZPM_ERR_TEXTrr��pmLookupLabelsr�rrr�ri)r#r�Zpmidr�r�r�found�rZhit�msgr�r�Zsp�crr��lineZfullZdomlZdomhr�r��	ri_labelsr$r$r%�check_metric.s�

( 
",
"


zpmConfig.check_metriccCst|jd�r|jjrdSdS)z& Check if unknown metrics are ignored �ignore_unknownTF)r�rr�)r#r$r$r%�ignore_unknown_metrics�szpmConfig.ignore_unknown_metricscCsTd|krP|jdd�jdd�}|jdd�jdd	�}|jd
d
�jdd�}|jdd
�}|S)z Format a metric text label z / Znanosec�nsZmicrosec�usZmillisecZmsZsecr��minZhour�h�/)r;)r#rr$r$r%�format_metric_label�szpmConfig.format_metric_labelc@s eZdZdZdd�Zdd�ZdS)zpmConfig.pmfg_items_to_indomzC Helper to provide consistent interface with pmfg items and indoms cCs
||_dS)z# Initialize an instance with items N)�_items)r#r�r$r$r%r&�sz%pmConfig.pmfg_items_to_indom.__init__cCs|jS)z Retrieve the items )r�)r#r$r$r%�__call__�sz%pmConfig.pmfg_items_to_indom.__call__N)�__name__�
__module__�__qualname__�__doc__r&r�r$r$r$r%�pmfg_items_to_indom�srcCsttj|t|���|S)z8 Round an integer value up to the nearest upper integer )rq�mathZceil�float)r#rt�upperr$r$r%�integer_roundup�szpmConfig.integer_roundupcCs�y�d}d}t|jd�r4|jjr4d}t|jj�|j_t|jd�r\|jjr\d}t|jj�|j_t|jd�r�|jjr�d}t|jj�|j_d}t|jd�r�|jjr�d}t|jj�|j_|jjdkr�t|��t|jd	�o�|jj�rd	}t|jj�|j_|jjdk�rt|��t|jd
��rF|jj	�rFd
}t|jj	�|j_	|jj	dk�rFt|��t|jd��r�|jj
�r�d}t|jj
�|j_
|jj
dk�r�t|��t|jd��r�|jj�r�d}|jjd
k�r�t|jj�|j_|jjdk�r�t|��Wn4tk
�rtj
jd||f�tjd�YnXdS)z! Validate common utility options zInteger expected�unknown�rank�limit_filter�limit_filter_forcezNon-negative integer expectedrr�width_forcer�precision_force�
repeat_header�autoz#Error while reading option %s: %s.
rN)r�rrrqr	r
rrrrrrr
r(r�r�r))r#rK�attrr$r$r%�validate_common_options�sTz pmConfig.validate_common_optionsrc">s�t�jd�st�j��j_t�jd�rb�jjrbx2�jjjd�D] }|�jjkr>dgg�jj|<q>W�jj�rB�x�td�jjjd��D�]�}|j	d�s�|j	d��r
y�jj
j|�WnTtj
k
�r}z4tjjd	�tjjd
|t|�f�tjd�WYdd}~XnXq�d}�z
y&|jdd�\}}�jj
j|j��Wn�tj
k
�r�}zr|jd
tjjk�rl|j�}nNy�jj
j|j�|j��w�Wn.tj
k
�r�}z|j�}WYdd}~XnXWYdd}~XnNtk
�r�}z
d}WYdd}~Xn(tk
�r}z
d}WYdd}~XnXWd|�r<tjjd|�tjd�Xq�Wt�jd��s^�jj�rr�jj�t��j_��fdd�}	x�t��D]�}
|
�_y�jj
j |
|	�Wn�tj
k
�rj}z�|jd
tjjk�r҂d}y�jj
j|
�WnVtj
k
�r>}z6|jd
tjjk�r��j!��r.|
�jk�r.d}WYdd}~XnX|�sZt�|
��jj|
<WYdd}~XnX�q�W�jj�t��j_x��D]�}
yTt"�j#�}�|
d�_�jj
j |
�j$�t"�j#�|k�rАw�n�|
�jj|
<WnHtj
k
�r*}z(tjjd|
t|�f�tjd�WYdd}~XnX�q�W�j%�r|�j!��r|tjjd��jj&�rrt'd�t'�jj&�tjd�|}
t�}�x�t(�jj�D�]�\}}
xZt)d
d�D]L}t"�jj|
�|k�r�|dk�r�jj|
j*g�n�jj|
j*d��q�W�jj|
d
�s`d}x$|
jd�D]}||d
d7}�q W|ddA�|
jd�dB�jj|
d
<�jj|
d�r��jj&�r��j%|d
d
tjj+k�r��jj&�jj|
d<�j%|d
d
tjj+k�r�g�jj|
d<|
�r��j,t"�j%|d
�d�}t�jd��r2�jj|
d�r2�jj-�jj|
d<n8�jj|
ddk�rZd�jj|
d<nd
�jj|
d<t�jd��r��jj.dk�s��jj|
ddk�s�t�jd��rȈjj/d k�r�d�jj|
d<d!d"�}d#d$�}d%d&�}�j0|j1j2}||��r�t�jd'��r&�jj3�r&�jj3�jj|
d<nht�jd(��rh�jj4�rh�jj|
d�rh�jj4�jj|
d<n&�jj|
d�s�t|��jj|
d<||��r.t�jd)��rƈjj5�rƈjj5�jj|
d<nht�jd*��r�jj6�r�jj|
d�r�jj6�jj|
d<n&�jj|
d�s.t|��jj|
d<||��r�t�jd+��rf�jj7�rf�jj7�jj|
d<nht�jd,��r��jj8�r��jj|
d�r��jj8�jj|
d<n&�jj|
d�s�t|��jj|
d<�jj|
d�s�t|��jj|
d<t�jd��	r$�jj/d k�	r$t|��jj|
d<y��jj|
d}�jj
j9�jj|
d�\}}�jj|
dd
k�	r��j0|j1j.tjj:k�	r��j0|j;tjj<k�	r�d|k�	r�|d-7}�j=|�}|||f�jj|
d<WnTtj
k
�
r }z4tjjd.t|��jj|
df�tjd�WYdd}~XnXtjj>}t|�t�j0|j1j2�k�
rT�j0|j1j.}�jj|
dd
k�
r��j0|j1j;tjj<k�
r�tjj>}�j0|j1j.tjj:k�
r��j0|j1j.}�jj|
d/�r4y>t?�jj|
d/��jj|
d/<�jj|
d/d
k�
r�t�Wn0tk
�r0tjjd0|
�tjd�YnXn4t�jd1��rX�jj@�jj|
d/<nd
�jj|
d/<t�jd2��r��jjAdk	�r��jjA�jj|
d/<�jj|
d/�s�t"�jj|
d
��jj|
d/<�jj|
d/t"tB�k�r�t"tB��jj|
d/<�jj|
d3�rby$t?�jj|
d3��jj|
d4<Wn0tk
�r^tjjd0|
�tjd�YnXn4t�jd5��r��jjC�jj|
d4<nd�jj|
d4<t�jd6��rƈjjDdk	�rƈjjD�jj|
d4<d�jj|
d3<�jj|
d7�
r@y$t?�jj|
d7��jj|
d7<Wn0tk
�
r<tjjd8|
�tjd�YnXn"t�jd9��
rb�jjE�jj|
d7<t�jd:��
r��jjF�
r��jjF�jj|
d7<�j0|j1j.tjj:k�
r�d�jj|
d7<�y2g}tGd|�}�jj|
dd
}|�r2�jj|
d�r2d
}g}x�t)d
t"�j%|d��D]�}yZ�jjHjI|
||�j%|d|�}|j*�j%|d
|�j%|d||f�|d7}WnFtj
k
�r�}z&|jd
tjjJk�r��|j*|�WYdd}~XnX�qW|d
k�rxLtK|�D]@} �j%|d
| =�j%|d| =�jL��rֈjM|d| =�q�W�jN|��jj|
d3<n �jjHjO|
|||��jj|
d3<�jP��r�yHg�jQ|
<x8�jj|
dD]$}!�jQ|
j*tRjSd;|!d<���qzWWnBtk
�r�}z$tjjd=|!|f�tjd�WYdd}~XnXWn:tk
�r$t�jd>��r�jjT�r|||
<n�YnX�q�WxltK|�D]`}
�j#||
=�j0||
=�j%||
=�jU��rt�jV||
=�jL��r��jM||
=�jj|
=�q6W~�jj�sԈj!��s�tjjd?�ntjjd@�tjd�t�jd��r�jj�r�jW�dS)Cz Validate the metricset �	leaf_only�	predicatercr7Nrbr�r�z*Failed to load derived metric definitions zfrom file '%s':
%s.
rr�rz+Invalid syntax (expected metric=expression)zUnidentified errorz'Failed to register derived metric:
%s.
csF|�jkr.|�jjkrBt��j��jj|<nt�|��jj|<dS)z( Helper to support non-leaf metricspecs N)r rr�r)r�)r�r#r$r%�metric_base_check
s
z4pmConfig.validate_metrics.<locals>.metric_base_checkFTzInvalid metric %s (%s).
zNo matching instances found.
z
Requested global instances:�r~i�rgr}rfr�output�archivecSs&|jdkr"|jdkr"|jdkr"dSdS)z Test count dimension rrTF)�dimCount�dimSpace�dimTime)r
r$r$r%�is_countps



z+pmConfig.validate_metrics.<locals>.is_countcSs&|jdkr"|jdkr"|jdkr"dSdS)z Test space dimension rrTF)rrr)r
r$r$r%�is_spacexs



z+pmConfig.validate_metrics.<locals>.is_spacecSs&|jdkr"|jdkr"|jdkr"dSdS)z Test time dimension rrTF)rrr)r
r$r$r%�is_time�s



z*pmConfig.validate_metrics.<locals>.is_time�count_scale_force�count_scale�space_scale_force�space_scale�time_scale_force�
time_scalez / sz%s: %s.
�z"Non-negative integer expected: %s
rr��rr�zInteger expected: %s
r	r
z\Az\ZzInvalid regex '%s': %s.
r�zNo compatible metrics found.
zNot one known metric found.
���rh)Xr�rrr!r�rrora�filterrBr�ZpmLoadDerivedConfigrr�r(r�r�rir)r��striprIr�ZPM_ERR_NAMEr�ZpmRegisterDerivedrrr/rrr�r ZpmTraversePMNSr�r�rr�rr�printr�r�rLr�rrgrrrr�Zunitsrrrr r!r"ZpmParseUnitsStrr�ZsemZPM_SEM_COUNTERr�r�rqrr�TRUNCrrr	r
�max�pmfgZextend_itemZPM_ERR_CONV�reversedr�rrZextend_indomr�rr�r�r�r�r�validate_predicate)"r#�
curr_insts�	max_instsrrar�rKrs�exprrr��ignore�lZ
dynamic_instsZincompat_metricsr�r�r�rrrr
rZunitstrZmultZmtyper�ZscaleZmitemsZvanished�j�itemr�r�r$)r�r#r%�validate_metrics�s�

*
	,


"


&"	




$  $$
","

 

( 





zpmConfig.validate_metricscCsn|jjj��r"|jjj�dkr$d}nt|jjj��}t|jjj��||j_|jjj�r�|jjj�|j_t	d|jj�|j_t|jj�|jjd|j_
|jjjt|jj
��|jjj
�|j_
nb|jjj
�|j_
|jj
s�tjd�|j_
y$t|jjt|jj
�d�|j_Wntk
�rYnXn |jjj�|j_|jjj
�|j_
t|jj
�dk�rjtjjd�tjd�dS)z Finalize util options Nrr~rz$Interval must be greater than zero.
)rrkZpmGetOptionFinishOptargZpmGetOptionOriginr�pmGetOptionFinishZruntimerlrdr,rermrirnrZtimevalrqr/r(r�r�r))r#�originr$r$r%�finalize_options;s.$zpmConfig.finalize_optionscCsHt�|j_g|_g|_g|_g|_g|_t�|_|jj	j
�d|j_dS)z Clear metricset N)rrr�rrrrrrr-�clear�pmfg_ts)r#r$r$r%�
clear_metricsZs
zpmConfig.clear_metricscCs(|j�|jjj�|j_|j||�dS)z Update metricset N)r=rr-Zextend_timestampr<r7)r#r0r1r$r$r%�update_metricsfszpmConfig.update_metricscCst|jd�r|jjSdS)zV Action to take when namespace change occurs:
            ignore=0, abort=1, update=2 �names_changer)r�rr?)r#r$r$r%�names_change_actionlszpmConfig.names_change_actioncCs�y|jjj�}Wn`tjk
rp}zB|jdtjjkr:dS|jdtjjkr\tjtjjd��|�WYdd}~XnX|jj	s�|jj
�jd�}|jjj
�}t|�t|�kr�d	S|tjj@r�|j�}|dkr�d
S|dkr�dSdS)z2 Sample using fetchgroup and handle special cases rrz+
No metrics or instances to report present.Nz%sr~r}rhr'���)rr-�fetchrr�rIr�Z
PM_ERR_EOLZPM_ERR_TOOSMALLZinterpolr<�strftimerkr8rZPMCD_NAMES_CHANGEr@)r#�stater�ZsampleZfinish�actionr$r$r%rBss*
zpmConfig.fetchcCsd|jd7_|js*t|jj�jd��|_|jt|jj�|j}|tj�}|dkr`tj|�dS)z Pause before next sampling rz%s.%frN)	rrrrr<rCre�time�sleep)r#�wakeuprGr$r$r%�pause�szpmConfig.pausecCs�|j|sdSxj|jj|dD]V}|jdd�jdd�jdd�j�r d|kr |j�dj�r ||j|j�d�kr dSq Wx"|j|D]}tj	||�r�dSq�Wd	S)
z/ Filter instance name against metric instances Trr�r7r�r�r�rF)
rrr�r;r�ror�r�r�r�)r#r�rsr�r�r$r$r%�filter_instance�s
 zpmConfig.filter_instancecCsB|jjs|St|jj�}t|jjdk�}t|dd�|d�d|�S)z Rank instances rcSs|dS)Nr~r$)rtr$r$r%�<lambda>�szpmConfig.rank.<locals>.<lambda>)r��reverseN)rr�abs�boolrM)r#rrZrevsr$r$r%r�s
z
pmConfig.rankcCs�x�|jjjd�D]�}||jjkr:tjjd|�tjd�t|jjj	��j
|�}|jj|j
|jj�|j|ddtjjkr�tjjd�tjd�|j
|jjtjjkrtjjd�tjd�qWdS)z- Validate predicate filter reference metrics rcz"Predicate metric %s filtered out.
rrz&Predicate metric must have instances.
z)Predicate metric values must be numeric.
N)rrror�r(r�r�r)r�rxr�rrLrr�r�rrr�r�rr�)r#rr�r$r$r%r/�s

zpmConfig.validate_predicateFcCs
|j|�S)z. Deprecated, use get_ranked_results() instead )�get_ranked_results)r#�
valid_onlyr$r$r%�get_sorted_results�szpmConfig.get_sorted_resultscs�t��t�jd�r*�jjr*�jjjd�}nf}�j�o>�j�}�x8t�jj�D�]&\}�g��<y�x�jj�d�D]�\}}}y�|t	j
jkr�|r�wx|r�|t	j
jkr��j�|�r�wx|�}�jj�d�r�|k�r�jj�d��dkr�|�kr�wxn�dk�r|t
��k�rwx��j|||f�Wqxtk
�rDYqxXqxWWntk
�rbYnX|rP��rP��=qPW�j��r��fdd��D�}	�j|	k�r��j}
t��_|	�_xֈD]Ήd}�|
k�r4|
�d}|
�d	j�����r
tt����dni}
t�fd
d�|
D���r^|
�d	}n*t�jjj��j��}�jjj�j|�}|dk�r|�j�j|jj�}||g�j�<�q�W��s��S|�ri�xft|�D]Z\}}�j�|��|<�j |���k�r�g��<��j!��fdd��|D���q�Wx�D]��|k�r��jj�d�r�jj�d��dk�rh�fd
d���D���<n$�dk�r�fdd���D���<�qt�jjj��j��}�j|jj�j k�r҈j�����<�q�j|jj���fdd���D���<�qWn:t�jd��r>�jj�r>x �D]��j�����<�q"W�j��r~�j��r~x*�D]"���fdd���D���<�qXW�S)z! Get filtered and ranked results rrcr$r&rcs,g|]$}�|r|tt�|��df�qS)r)r��zip)r�r�)�resultsr$r%�
<listcomp>�sz/pmConfig.get_ranked_results.<locals>.<listcomp>Nrc3s|]}|�kVqdS)Nr$)r�r�)�
prev_instsr$r%r��sz.pmConfig.get_ranked_results.<locals>.<genexpr>c3s&|]}|d��kr|dVqdS)rNr$)r��x)�p�
pred_instsr$r%r�scsg|]}|d�kr|�qS)r~r$)r�rV)rr$r%rTscs g|]}|dt��kr|�qS)r~)rM)r�rV)rr$r%rTscs g|]}|d��kr|�qS)rr$)r�rV)�
inst_indexrXr$r%rT$srcs g|]}�j�|d�r|�qS)r)rJ)r�rV)r�r#r$r%rT,s)"rr�rrror�r�r�r�rr�r�rJrMrLr/r�r"rrxr�rR�allr�r�r�rr�rr�r�rrr�)r#rPZ
predicatesZearly_live_filterr�r�rs�valrtrZprev_labelsr�r�r0rr$)rYrr�rWrXrUrSr#r%rO�s�




"


(



$

"zpmConfig.get_ranked_results)NTT)F)F)1r�r�rrr&r0r3r1rSrur|r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r��objectrrr�
CURR_INSTSr7r:r=r>r@rBrIrJrr/rQrOr$r$r$r%r,s\&'
/


`

-d
r)rr�r�collectionsrZconfigparserr��ImportErrorr.rFrr�r(r8r�Zpcprr+�VERSIONr]r\rr$r$r$r%�<module>s$