403Webshell
Server IP : 80.87.202.40  /  Your IP : 216.73.216.169
Web Server : Apache
System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64
User : bitrix ( 600)
PHP Version : 8.2.27
Disable Function : NONE
MySQL : OFF |  cURL : ON |  WGET : ON |  Perl : ON |  Python : OFF |  Sudo : ON |  Pkexec : ON
Directory :  /usr/lib64/python3.9/site-packages/mercurial/__pycache__/

Upload File :
current_dir [ Writeable] document_root [ Writeable]

 

Command :


[ Back ]     

Current File : /usr/lib64/python3.9/site-packages/mercurial/__pycache__/hbisect.cpython-39.opt-1.pyc
a

�+�b�+�@s�ddlmZddlZddlZddlmZddlmZmZddl	m
Z
dd�Zd	d
�Zdd�Z
d
d�Zdd�Zdd�Zejdd��Zdd�Zdd�Zdd�ZdS)�)�absolute_importN�)�_)�hex�short)�errorcs������j��j}�fdd�|dD����fdd�}d}||d|d�\�}|spd	}||d|d�\�}����}|s�t|d�d
kr�t|d�d
kr�|d|dkr�t�td���t�td��t|�f��i}t	�
�g�}g}	|�rX|��}
||
gkr�|	�|
�||
�D]>}|d
k�r||v�r>||�|
�n|
g||<|�|��qq�|	�
�t|	�}��fdd�|	D�}
|d
k�s�|
�s��fdd�|	D�d|fS|d}d}d
}t�}|	D]�}
|
|v�r�|�|�|
g���q�||
�p�|
g}d||
<t|�}||}t||�}||k�r@|
�v�r@|}|
}||k�r@�q�||k�rj|
�v�rj|�|�|
g���q�|�|
g�D]8}||�r�tt|||��||<n||g||<�qv�q���|�}|g||fS)a�find the next node (if any) for testing during a bisect search.
    returns a (nodes, number, good) tuple.

    'nodes' is the final result of the bisect if 'number' is 0.
    Otherwise 'number' indicates the remaining possible candidates for
    the search and 'nodes' contains the next bisect target.
    'good' is True if bisect is searching for a first good changeset, False
    if searching for a first bad one.
    csh|]}��|��qS���rev��.0�n��	changelogr�7/usr/lib64/python3.9/site-packages/mercurial/hbisect.py�	<setcomp>&�zbisect.<locals>.<setcomp>�skipcs\t�fdd�|D��}t�dd��}��d||�D]}g||<q2||durT|dfS||fS)Ncsg|]}��|��qSrr	rrrr�
<listcomp>)rz2bisect.<locals>.buildancestors.<locals>.<listcomp>cSsdS)Nrrrrr�<lambda>*rz0bisect.<locals>.buildancestors.<locals>.<lambda>s!descendants(%ln) - ancestors(%ln))�min�collections�defaultdict�revs)�bad�good�badrev�	ancestorsr
)r�reporr�buildancestors(s
zbisect.<locals>.buildancestorsF�bad�goodTrs+starting revisions are not directly relateds)inconsistent state, %d:%s is good and bad���cs g|]}|�vr|�kr|�qSrr�r�c)r�skiprrrWrzbisect.<locals>.<listcomp>csg|]}��|��qSr��noder#rrrrYrr�N)�
unfilteredrZ
parentrevsr'�lenr�Abortrrr�deque�popleft�append�sort�set�update�getr�list)r�stateZ	clparentsrrrrZchildrenZvisitZ
candidatesr
�prevZtotZ	unskippedZperfectZbest_revZbest_lenZpoison�a�x�y�valuer$Z	best_noder)rrrr%r�bisects�	
���
��








r:cCsj||d��}t|�dkrf|r*|d}n|d}tdd�|D�t|�@�}|dkrf|d�|d�SdS)Nrrr r!cSsh|]}|���qSrr&)r�irrrr�rzextendrange.<locals>.<setcomp>)�parentsr*r0Zancestor)rr4�nodesrr<ZsideZnumrrr�extendrange�s
r>cCsnggggd�}|j�d�D]N}|dd���\}}|���|�}||vrZt�td�|��||�|�q|S)N)�currentr!r r�bisect.stater"sunknown bisect kind %s)	�vfsZtryreadlines�splitr)�lookuprr+rr.)rr4�l�kindr'rrr�
load_state�srFc	Csv|jdddd�}|���Jt|�D](}||D]}|�d|t|�f�q.q"|��Wd�n1sh0YdS)Nr@�wT)Z
atomictemps%s %s
)rAZwlock�sorted�writer�close)rr4�frEr'rrr�
save_state�s
rLcCs|j�d�r|j�d�dS)z+remove any bisect state from the repositoryr@N)rA�exists�unlink)rrrr�
resetstate�srOcCs>|dr|drdS|ds,t�td���nt�td���dS)z`check we have both 'good' and 'bad' to define a range

    Raise StateError exception otherwise.r!r Ts'cannot bisect (no known good revisions)s&cannot bisect (no known bad revisions)N)rZ
StateErrorr)r4rrr�
checkstate�s
rPc	cs:zdVW|g|d<t||�n|g|d<t||�0dS)Nr?)rL)rr4r'rrr�
restore_state�s
�
rQc
Cst|�}|dvr&t|��jj||�Sd}|�d�}t|�dkrJd}d}nd}d}d	}d
|||f}d||f}	d}
d
}d|
||f}|dkr�|�|�S|dkr�|�|�S|dkr�|�|	�S|dkr�|�|�S|dkr�|�|�S|dk�r�|�|�St�t	d���dS)a
    Return a list of revision(s) that match the given status:

    - ``good``, ``bad``, ``skip``: csets explicitly marked as good/bad/skip
    - ``goods``, ``bads``      : csets topologically good/bad
    - ``range``              : csets taking part in the bisection
    - ``pruned``             : csets that are goods, bads or skipped
    - ``untested``           : csets whose fate is yet unknown
    - ``ignored``            : csets ignored due to DAG topology
    - ``current``            : the cset currently being bisected
    )r!r rr?s9( bisect(bad)::bisect(good) | bisect(good)::bisect(bad) )sbisect(good)::bisect(bad)rsbisect(good)::s
::bisect(bad)s::bisect(good)s
bisect(bad)::sbisect(skip)s( (%s) | (%s) | (%s) )s( (%s) - (%s) )s::bisect(bad) - ::bisect(good)s::bisect(good) - ::bisect(bad)s( ( (%s) | (%s) ) - (%s) )srangespruned�untested�ignored�goods�badssinvalid bisect stateN)
rF�mapr)rr
rr*rZ
ParseErrorr)
r�statusr4�rangeZ_tZgoodsZbadsZskipsZprunedZuntestedZibaZigaZignoredrrrr2�s:








r2cCs�|j�|�}|t|d�vr"td�S|t|d�vr8td�S|t|d�vrNtd�S|t|d�vsj|t|d�vrrtd�S|t|d�vr�td�S|t|d�vr�td	�S|t|d
�vr�td�SdS)Nr!r rsskippedrRr?rSrTsgood (implicit)rUsbad (implicit))rr
r2r)rr'r
rrr�labels rYcCs�|��}t|�dkrr|r(|�td��n|�td��|�||d�t||||�}|dur�|�td�|�n:|r�|�td��n|�td��|D]}|�||�q�|��dS)NrsThe first good revision is:
sThe first bad revision is:
rs�Not all ancestors of this changeset have been checked.
Use bisect --extend to continue the bisection from
the common ancestor, %s.
sCDue to skipped revisions, the first good revision could be any of:
sBDue to skipped revisions, the first bad revision could be any of:
)r)r*rIrZshowr>rJ)Zuirr4Z	displayerr=rZ
extendnoder
rrr�printresult$s:���
����rZ)Z
__future__rr�
contextlibZi18nrr'rr�rr:r>rFrLrOrP�contextmanagerrQr2rYrZrrrr�<module>s k	
D

Youez - 2016 - github.com/yon3zu
LinuXploit