U
    (cDn                  R   @   sb  d Z ddlmZ ddlmZ ddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlZddlZddlZddlmZ ddl	mZ ddl	mZ ddl	mZ zdd	l	mZ W n ek
r   dZY nX zdd
l	mZ W n ek
r   dZY nX ejdkrddlZndZejd dkZeeddZe Zddddddddddddddddddd d!d"d#d$d%d&d'd(d)d*d+d,d-d.d/d0d1d2d3d4d5d6d7d8d9d:d;d<d=d>d?d@dAdBdCdDdEdFdGdHdIdJdKdLdMdNdOdPdQdRdSdTdUdVdWdXdYdZd[d\d]d^d_gRZejd`kZejdakZ ej!"dbZ#ej!"dcZ$e$Z%ej!"ddZ&ej!"deZ'ej!"dfZ(e&p8e'p8e(Z)ej!"dgZ*ej!"dhZ+diZ,djZ-dkZ.dlZ/dmZ0dnZ1doZ2dpZ3dqZ4drZ5dsZ6dtZ7duZ8dvZ9dwZ:dxZ;dyZ<dzZ=d{Z>d|Z?d}Z@d~ZAdZBdZCdZDdZEedkrdZFdZGdZHn G dd dejIZJeK LeJjM edkrdZNdZOn G dd dejIZPeK LePjM eQ ZRes:dZSn2zeT ZSW n$ eUk
rj   erbdndZSY nX edIddddddgZVedEddddgZWedCddddddgZXedDddddddgZYedFddddddddgZZedJdddddgZ[edAdddddddgZ\edGdddddgZ]edHdddddgZ^edBddddgZ_eddddgZ`edddddgZaeddddgZbedddgZced9ddddgZded>ddgZeed?dddgZfed@dddgZged;dddgZhed<ddddgZied=ddgZjed:ddgZked8ddddddgZledddgZmeeegeegfeegegfegegfeegegfegegfeegeegfegeegfegeegfdݜZnedk	renLegegfegegfdޜ edk	renLdegeegfi G dd deoZpG dd depZqG dd deqZrG dd depZsG dd depZtd
ddQZuddN Zvdd ZwddM ZxddP ZyevddR ZzddO Z{ddS Z|ddT Z}ddd[Z~ddL ZG dd dZddU Ze Zeje_eje_dZddW ZddV ZeefddXZefddYZdddZZd d Zerdd Zndd Zevejfdd^Zddd]Zddejfdd_Zd	d\ ZdS (  z9Common objects shared by __init__.py and _ps*.py modules.    )division)print_functionN)
namedtuple)AF_INET)
SOCK_DGRAM)SOCK_STREAM)AF_INET6)AF_UNIX)      r
   PSUTIL_DEBUGFREEBSDBSDLINUXNETBSDOPENBSDMACOSOSXPOSIXSUNOSWINDOWS
CONN_CLOSECONN_CLOSE_WAITCONN_CLOSINGCONN_ESTABLISHEDCONN_FIN_WAIT1CONN_FIN_WAIT2CONN_LAST_ACKCONN_LISTEN	CONN_NONECONN_SYN_RECVCONN_SYN_SENTCONN_TIME_WAITNIC_DUPLEX_FULLNIC_DUPLEX_HALFNIC_DUPLEX_UNKNOWNSTATUS_DEADSTATUS_DISK_SLEEPSTATUS_IDLESTATUS_LOCKEDSTATUS_RUNNINGSTATUS_SLEEPINGSTATUS_STOPPEDSTATUS_SUSPENDEDSTATUS_TRACING_STOPSTATUS_WAITINGSTATUS_WAKE_KILLSTATUS_WAKINGSTATUS_ZOMBIESTATUS_PARKEDENCODINGENCODING_ERRSr   pconn	pcputimespctxswpgidspiopionice	popenfilepthreadpuidssconn	scpustatssdiskio	sdiskpart
sdiskusagesnetiosnicaddr	snicstatssswapsuser	conn_tmapdeprecated_methodisfile_strictmemoizeparse_environ_blockpath_exists_strictusage_percentsupports_ipv6sockfam_to_enumsocktype_to_enumwrap_numbers	open_textopen_binarycatbcatbytes2humanconn_to_ntupledebughiliteterm_supports_colorsprint_colorposixntlinuxdarwin)ZfreebsdZmidnightbsdZopenbsdZnetbsd)sunossolarisaixZrunningZsleepingz
disk-sleepstoppedztracing-stopZzombieZdeadz	wake-killZwakingZidlelockedZwaitingZ	suspendedZparkedZESTABLISHEDZSYN_SENTZSYN_RECVZ	FIN_WAIT1Z	FIN_WAIT2Z	TIME_WAITZCLOSEZ
CLOSE_WAITZLAST_ACKZLISTENZCLOSINGNONE      c                   @   s   e Zd ZdZdZdZdS )	NicDuplexrh   ri   r   N)__name__
__module____qualname__r#   r$   r%    rn   rn   2/tmp/pip-unpacked-wheel-l83rk7k5/psutil/_common.pyrj      s   rj   c                   @   s   e Zd ZdZdZdS )BatteryTimerp   rq   N)rk   rl   rm   POWER_TIME_UNKNOWNPOWER_TIME_UNLIMITEDrn   rn   rn   ro   rr      s   rr   replacesurrogateescapetotalusedfreepercentsinZsoutZ
read_countZwrite_count
read_byteswrite_bytesZ	read_timeZ
write_timeZdeviceZ
mountpointZfstypeoptsZmaxfileZmaxpathZ
bytes_sentZ
bytes_recvZpackets_sentZpackets_recvZerrinZerroutZdropinZdropoutnameZterminalhoststartedpidfdfamilytypeladdrraddrstatusaddressnetmask	broadcastZptpZisupZduplexspeedZmtuflagsZctx_switchesZ
interruptsZsoft_interruptsZsyscallsscpufreqcurrentminmaxshwtemplabelhighcriticalsbatteryZsecsleftZpower_pluggedsfanusersystemchildren_userchildren_systempathidZ	user_timeZsystem_timerealZ	effectiveZsavedZioclassvalueZ	voluntaryZinvoluntaryaddripport)allZtcpZtcp4ZudpZudp4ZinetZinet4Zinet6)Ztcp6Zudp6unixc                   @   s,   e Zd ZdZdZdd Zdd Zdd Zd	S )
ErrorzQBase exception class. All other psutil exceptions inherit
    from this one.
    psutilc                 C   sH   t  }|D ]6}t| |d }|r*|||< q|dkr|dkr|||< q|S )Nr   r   )collectionsOrderedDictgetattr)selfattrsinfor   r   rn   rn   ro   	_infodict  s    

zError._infodictc                 C   sP   |  d}|r,dddd | D  }nd }ddd t| dd	|fD S )
N)r   ppidr   z(%s), c                 S   s   g | ]\}}d ||f qS z%s=%rrn   .0kvrn   rn   ro   
<listcomp>+  s     z!Error.__str__.<locals>.<listcomp> c                 S   s   g | ]}|r|qS rn   rn   )r   xrn   rn   ro   r   .  s      msg )r   joinitemsr   r   r   detailsrn   rn   ro   __str__&  s    
zError.__str__c                 C   s2   |  d}ddd | D }d| jj|f S )N)r   r   r   secondsr   r   c                 S   s   g | ]\}}d ||f qS r   rn   r   rn   rn   ro   r   3  s     z"Error.__repr__.<locals>.<listcomp>zpsutil.%s(%s))r   r   r   	__class__rk   r   rn   rn   ro   __repr__0  s    
zError.__repr__N)rk   rl   rm   __doc__r   r   r   rn   rn   rn   ro   r     s
   

r   c                   @   s   e Zd ZdZdZdddZdS )NoSuchProcesszXException raised when a process with a certain PID doesn't
    or no longer exists.
    r   Nc                 C   s$   t |  || _|| _|pd| _d S )Nzprocess no longer existsr   __init__r   r   r   r   r   r   r   rn   rn   ro   r   =  s    
zNoSuchProcess.__init__)NNrk   rl   rm   r   r   rn   rn   rn   ro   r   7  s   r   c                   @   s   e Zd ZdZdZdddZdS )ZombieProcessa1  Exception raised when querying a zombie process. This is
    raised on macOS, BSD and Solaris only, and not always: depending
    on the query the OS may be able to succeed anyway.
    On Linux all zombie processes are querable (hence this is never
    raised). Windows doesn't have zombie processes.
    r   Nc                 C   s$   t | ||| || _|pd| _d S )Nz"PID still exists but it's a zombie)r   r   r   r   )r   r   r   r   r   rn   rn   ro   r   M  s    zZombieProcess.__init__)NNNr   rn   rn   rn   ro   r   D  s   r   c                   @   s   e Zd ZdZdZdddZdS )AccessDeniedz@Exception raised when permission to perform an action is denied.r   Nc                 C   s$   t |  || _|| _|pd| _d S )Nr   r   r   rn   rn   ro   r   W  s    
zAccessDenied.__init__)NNNr   rn   rn   rn   ro   r   S  s   r   c                   @   s   e Zd ZdZdZdddZdS )TimeoutExpiredzWRaised on Process.wait(timeout) if timeout expires and process
    is still alive.
    r   Nc                 C   s*   t |  || _|| _|| _d| | _d S )Nztimeout after %s seconds)r   r   r   r   r   r   )r   r   r   r   rn   rn   ro   r   d  s
    
zTimeoutExpired.__init__)NNr   rn   rn   rn   ro   r   ^  s   r   c                 C   sF   zt | | d }W n tk
r*   Y dS X |dk	r>t||}|S dS )z5Calculate percentage usage of 'used' against 'total'.d   g        N)floatZeroDivisionErrorround)rx   rw   Zround_retrn   rn   ro   rO   q  s    
c                    s2   t  fdd} fdd}i  ||_|S )a  A simple memoize decorator for functions supporting (hashable)
    positional arguments.
    It also provides a cache_clear() function for clearing the cache:

    >>> @memoize
    ... def foo()
    ...     return 1
        ...
    >>> foo()
    1
    >>> foo.cache_clear()
    >>>
    c                     sN   | t t| f}z
 | W S  tk
rH   | | } |< | Y S X d S N)	frozensetsortedr   KeyError)argskwargskeyr   cachefunrn   ro   wrapper  s    
zmemoize.<locals>.wrapperc                      s       dS )zClear cache.N)clearrn   )r   rn   ro   cache_clear  s    zmemoize.<locals>.cache_clear)	functoolswrapsr   )r   r   r   rn   r   ro   rL   }  s    c                    s6   t   fdd}dd }dd }||_||_|S )a  A memoize decorator which is disabled by default. It can be
    activated and deactivated on request.
    For efficiency reasons it can be used only against class methods
    accepting no arguments.

    >>> class Foo:
    ...     @memoize
    ...     def foo()
    ...         print(1)
    ...
    >>> f = Foo()
    >>> # deactivated (default)
    >>> foo()
    1
    >>> foo()
    1
    >>>
    >>> # activated
    >>> foo.cache_activate(self)
    >>> foo()
    1
    >>> foo()
    >>> foo()
    >>>
    c                    sn   z| j   }W nZ tk
r*    |  Y S  tk
rh    | }z|| j  < W n tk
rb   Y nX Y nX |S r   )_cacheAttributeErrorr   )r   r   r   rn   ro   r     s    z'memoize_when_activated.<locals>.wrapperc                 S   s
   i | _ dS )zjActivate cache. Expects a Process instance. Cache will be
        stored as a "_cache" instance attribute.N)r   procrn   rn   ro   cache_activate  s    z.memoize_when_activated.<locals>.cache_activatec                 S   s"   z| ` W n tk
r   Y nX dS )zDeactivate and clear cache.N)r   r   r   rn   rn   ro   cache_deactivate  s    z0memoize_when_activated.<locals>.cache_deactivate)r   r   r   r   )r   r   r   r   rn   r   ro   memoize_when_activated  s    r   c              
   C   s\   zt | }W n< tk
rJ } z|jtjtjfkr4 W Y dS d}~X Y nX t|jS dS )zSame as os.path.isfile() but does not swallow EACCES / EPERM
    exceptions, see:
    http://mail.python.org/pipermail/python-dev/2012-June/120787.html
    FN)osstatOSErrorerrnoEPERMEACCESS_ISREGst_mode)r   sterrrn   rn   ro   rK     s    c              
   C   sT   zt |  W n< tk
rJ } z|jtjtjfkr4 W Y dS d}~X Y nX dS dS )zSame as os.path.exists() but does not swallow EACCES / EPERM
    exceptions, see:
    http://mail.python.org/pipermail/python-dev/2012-June/120787.html
    FNT)r   r   r   r   r   r   )r   r   rn   rn   ro   rN     s    c               	   C   sd   t jrtdkrdS z4t  tt j} t|  | d W 5 Q R X W dS  t jk
r^   Y dS X dS )z2Return True if IPv6 is supported on this platform.NF)z::1r   T)sockethas_ipv6r   r   
contextlibclosingbinderror)sockrn   rn   ro   rP     s    c                 C   sv   i }d}t }| d|}||kr"qr| d||}||krh| || }| |d | }|r`| }|||< |d }q|S )zCParse a C environ block of environment variables into a dictionary.r    =ri   )r   findupper)datar   posZWINDOWS_Znext_posZ	equal_posr   r   rn   rn   ro   rM     s    
c                 C   s6   t dkr| S zt| W S  tk
r0   |  Y S X dS )zConvert a numeric socket family value to an IntEnum member.
    If it's not a known member, return the numeric value itself.
    N)enumr   AddressFamily
ValueErrornumrn   rn   ro   rQ   $  s    c                 C   s6   t dkr| S zt| W S  tk
r0   |  Y S X dS )zConvert a numeric socket type value to an IntEnum member.
    If it's not a known member, return the numeric value itself.
    N)r   r   
SocketKindr   r  rn   rn   ro   rR   1  s    c                 C   s   |t jtfkr&|rt| }|r&t| }|t jkrJ|ttfkrJ||t}nt}t|}t|}|dkrxt	| |||||S t
| ||||||S dS )z2Convert a raw connection tuple to a proper ntuple.N)r   r   r   r   r   getr   rQ   rR   r6   r?   )r   Zfamtype_r   r   r   Z
status_mapr   rn   rn   ro   rY   >  s    c                    s    fdd}|S )zA decorator which can be used to mark a method as deprecated
    'replcement' is the method name which will be called instead.
    c                    s:   d| j f  | jd kr | _t|  fdd}|S )Nz8%s() is deprecated and will be removed; use %s() insteadc                    s    t j tdd t| ||S )Nrh   )category
stacklevel)warningswarnDeprecationWarningr   )r   r   r   )r   replacementrn   ro   inner[  s    z/deprecated_method.<locals>.outer.<locals>.inner)rk   r   r   r   )r   r  r  )r   ro   outerU  s     
z deprecated_method.<locals>.outerrn   )r  r  rn   r  ro   rJ   Q  s    c                   @   sB   e Zd ZdZdd Zdd Zdd Zdd	 ZdddZdd Z	d
S )_WrapNumberszNWatches numbers so that they don't overflow and wrap
    (reset to zero).
    c                 C   s    t  | _i | _i | _i | _d S r   )	threadingLocklockr   	remindersreminder_keysr   rn   rn   ro   r   h  s    
z_WrapNumbers.__init__c                 C   sX   || j kst|| jkst|| jks*t|| j |< tt| j|< tt| j|< d S r   )r   AssertionErrorr  r  r   defaultdictintset)r   
input_dictr   rn   rn   ro   	_add_dictn  s    
z_WrapNumbers._add_dictc                 C   s\   | j | }t| t|  }|D ]0}| j| | D ]}| j| |= q8| j| |= q&dS )zIn case the number of keys changed between calls (e.g. a
        disk disappears) this removes the entry from self.reminders.
        N)r   r  keysr  r  )r   r  r   old_dictZ	gone_keysZgone_keyremkeyrn   rn   ro   _remove_dead_remindersv  s    
z#_WrapNumbers._remove_dead_remindersc              	   C   s
  || j kr| || |S | || | j | }i }| D ]}|| }z|| }W n  tk
rt   |||< Y q<Y nX g }tt|D ]f}	||	 }
||	 }||	f}|
|k r| j| |  |7  < | j| | 	| |
|
| j| |   qt|||< q<|| j |< |S )zkCache dict and sum numbers which overflow and wrap.
        Return an updated copy of `input_dict`
        )r   r  r  r  r   rangelenr  r  addappendtuple)r   r  r   r  Znew_dictr   Zinput_tupleZ	old_tuplebitsiZinput_value	old_valuer  rn   rn   ro   run  s2    



z_WrapNumbers.runNc              	   C   sh   | j X |dkr0| j  | j  | j  n*| j|d | j|d | j|d W 5 Q R X dS )z>Clear the internal cache, optionally only for function 'name'.N)r  r   r   r  r  pop)r   r   rn   rn   ro   r     s    

z_WrapNumbers.cache_clearc              
   C   s.   | j  | j| j| jfW  5 Q R  S Q R X dS )z5Return internal cache dicts as a tuple of 3 elements.N)r  r   r  r  r  rn   rn   ro   
cache_info  s    z_WrapNumbers.cache_info)N)
rk   rl   rm   r   r   r  r  r(  r   r*  rn   rn   rn   ro   r  c  s   '
r  c              
   C   s*   t j t | |W  5 Q R  S Q R X dS )zGiven an `input_dict` and a function `name`, adjust the numbers
    which "wrap" (restart from zero) across different calls by adding
    "old value" to "new value" and return an updated dict.
    N)_wnr  r(  )r  r   rn   rn   ro   rS     s    i   c                 C   s   t | dtdS )Nrb	buffering)openFILE_READ_BUFFER_SIZE)fnamern   rn   ro   rU     s    c                 C   sd   t st| dtdS t| dtttd}z
t|_W n0 tk
rB   Y n tk
r^   |   Y nX |S )zOn Python 3 opens a file in text mode by using fs encoding and
    a proper en/decoding errors handler.
    On Python 2 this is just an alias for open(name, 'rt').
    rtr-  )r.  encodingerrors)	PY3r/  r0  r4   r5   _CHUNK_SIZEr   	Exceptionclose)r1  Zfobjrn   rn   ro   rT     s     
c              
   C   sz   |t kr.|| }| W  5 Q R  S Q R X nHz*|| }| W  5 Q R  W S Q R X W n ttfk
rt   | Y S X dS )zRead entire file content and return it as a string. File is
    opened in text mode. If specified, `fallback` is the value
    returned in case of error, either if the file does not exist or
    it can't be read().
    N)_DEFAULTreadIOErrorr   )r1  fallback_openfrn   rn   ro   rV     s    

 c                 C   s   t | |tdS )z,Same as above but opens file in binary mode.)r<  r=  )rV   rU   )r1  r<  rn   rn   ro   rW     s    %(value).1f%(symbol)sc                 C   s   d}i }t |dd D ]\}}d|d d > ||< qt|dd D ].}| || krFt| ||  }|t    S qF|t|d | d S )zUsed by various scripts. See:
    http://goo.gl/zeJZl

    >>> bytes2human(10000)
    '9.8K'
    >>> bytes2human(100001221)
    '95.4M'
    )	BKMGTPEZYri   N
   r   )symbolr   )	enumeratereversedr   localsdict)nformatsymbolsprefixr&  srJ  r   rn   rn   ro   rX     s    	c                   C   s   t jd jS )z+Return updated psutil.PROCFS_PATH constant.r   )sysmodulesZPROCFS_PATHrn   rn   rn   ro   get_procfs_path  s    rV  c                 C   s   | j ttdS )N)r3  r4  )decoder4   r5   rS  rn   rn   ro   rW  %  s    rW  c                 C   s   | S r   rn   rX  rn   rn   ro   rW  (  s    c                 C   s`   t jdkrdS z2dd l}|  s$t|  |ddks>tW n tk
rV   Y dS X dS d S )Nr_   Tr   colorsF)r   r   cursesisattyr  Z	setuptermZtigetnumr7  )filerZ  rn   rn   ro   r\   1  s    
Fc                 C   s   t  s
| S g }tddddddddd	d
	}d|d< z|| }W n( tk
rd   tdt|  Y nX || |r~|d dd|| f S )z*Return an highlighted version of 'string'.Z32Z91Z33Z93Z34Z35Z36Z37Z30)	greenredbrownyellowZblueZvioletZ	lightblueZgreyZdarkgreyZ29Nz#invalid color %r; choose between %s1z[%sm%s[0m;)r\   rN  r   r   listr  r#  r   )rS  colorboldattrrY  rn   rn   ro   r[   @  s(       


c              	   C   s  t  st| |d ntr.tt| |||d nddl}d}|jjj}|jjj}t	ddddd}||d< z|| }W n, t
k
r   td	|t| f Y nX |r|dkr|d
7 }|tjkrdnd}	|j|_||	}
||
| zt| |d W 5 ||
| X dS )z$Print a colorized version of string.r\  r   N   rh   r      )r]  r^  r_  r`  z#invalid color %r; choose between %r   ii)r\   printr   r[   ctypeswindllKernel32GetStdHandleSetConsoleTextAttributerN  r   r   rc  r  rT  stderrc_ulongrestype)rS  rd  re  r\  rl  ZDEFAULT_COLORro  rp  rY  Z	handle_idhandlern   rn   ro   r]   S  s6    
 

c                 C   sn   t rjddl}|| j\}}}}}t| trRt| ttt	frJd|  } nd|  } t
d||| f tjd dS )z@If PSUTIL_DEBUG env var is set, print a debug message to stderr.r   Nzignoring %szignoring %rzpsutil-debug [%s:%s]> %srg  )r   inspectgetframeinfocurrentframef_back
isinstancer7  r   r;  EnvironmentErrorrk  rT  rq  )r   ru  r1  lineno	func_namelinesindexrn   rn   ro   rZ   v  s    

)N)N)r?  )NF)r   
__future__r   r   r   r   r   r   r   r   r   rT  r  r  r   r   r   r   r   ImportErrorr	   version_infor   r5  boolgetenvr   objectr9  __all__r   r   r   platform
startswithr   r   r   r   r   r   r   r   ZAIXr*   r+   r'   r,   r.   r2   r&   r0   r1   r(   r)   r/   r-   r3   r   r!   r    r   r   r"   r   r   r   r   r   r   r#   r$   r%   IntEnumrj   globalsupdate__members__rs   rt   rr   getfilesystemencodingr4   r5   getfilesystemencodeerrorsr   rG   rC   rA   rB   rD   rH   r?   rE   rF   r@   r   r   r   r   r7   r<   r=   r>   r9   r:   r;   r8   r6   r   rI   r7  r   r   r   r   r   rO   rL   r   rK   rN   rP   rM   rQ   rR   rY   rJ   r  rS   r+  r   r*  r0  rU   rT   rV   rW   rX   rV  rW  stdoutr\   r[   r]   rZ   rn   rn   rn   ro   <module>   s@  


                                                              %

	


        
 

 	





 
! ?
W		  #