^c6ddlZddlmZddlmZmZddlmZmZm Z m Z m Z ddl m Z dZdZGdd Zd6d Zd Zd Zd7dZd7dZdZdZdZdZdZdZdZdZdZdZdZ ej!dej!dej!dej!dgZ"dZ#dZ$dZ%d Z&d!Z'd8d"Z(Gd#d$e)Z*d9d%Z+d&Z,d'Z-d(Z.d)Z/d*Z0d+Z1d,Z2ed-ed.ed/ed0ed1d2Z3d3Z4d4Z5d5Z6dS):N)_)hexshort)diffutilencodingerrorphasesutil)dateutilcHeZdZdZdZdZdZdZdZdZ dZ d Z d Z d S) markerzWrap obsolete marker raw datac0||_||_d|_dSN)_repo_data _decodedmeta)selfrepodatas 3/usr/lib/python3/dist-packages/mercurial/obsutil.py__init__zmarker.__init__>s   c*t|jSr)hashrrs r__hash__zmarker.__hash__DsDJrcft|t|krdS|j|jkSNF)typerrothers r__eq__z marker.__eq__Gs- ;;$t** $ $5zU[((rc|jdS)z%Predecessor changeset node identifierrrrs rprednodezmarker.prednodeLz!}rc|jdS)z-List of successor changesets node identifiersrr&rs r succnodeszmarker.succnodesPr(rc|jdS)z2Parents of the predecessors (None if not recorded)r&rs r parentnodeszmarker.parentnodesTr(rc6t|jdS)zDecoded metadata dictionary)dictrrs rmetadatazmarker.metadataXsDJqM"""rc|jdS)z#Creation date as (unixtime, offset)r&rs rdatez marker.date\r(rc|jdS)zThe flags field of the markerr r&rs rflagsz marker.flags`r(rN) __name__ __module__ __qualname____doc__rrr$r'r*r-r1r4r6rrrr;s''!!!    ))) ###rrFc#K||j}n-|rt||}n|j|}|D]}t||VdS)zreturns markers known in a repository If is specified, only markers "relevant" to those nodes are are returnedN)obsstoreexclusivemarkersrelevantmarkersr)rnodes exclusive rawmarkers markerdatas r getmarkersrDesv  }] :%dE22 ]22599  '' T:&&&&&&''rc&t|dS)Nc.|dd|dpdfzS)Nr;r;)ms rzsortedmarkers..ws3B31R5;B.)@r)keysortedmarkerss r sortedmarkersrOus '@@ A A AArc#0K|jj}|g}t|}|rs|}||d}|D]B}|d}||vr||||vr|V-||C|qdSdS)zyield the list of next predecessors pointing on visible changectx nodes This function respect the repoview filtering, filtered revision will be considered missing. r;rN)r= predecessorssetpopgetaddappend) rnodeid precursorsstackseencurrent currentpreccsprec precnodeids rclosestpredecessorsr_zs+J HE u::D )))++"w33 ! ) )DaJT!! HHZ T!!      Z(((( )))))rc#<Kt|}t|}|jj}|rm|}|V||dD]D}|d|zr|d}||vr*||||E|kdSdS)zYield node for every precursors of . Some precursors may be unknown locally. This is a linear yield unsuited to detecting folded changesets. It includes initial nodes too.r;r rN)rRrQrTrSrU) r=r@ ignoreflags remainingrZr]r[marksucs rallpredecessorsresE I y>>D  $D  #--// D"%% # #DAw$ q'C$  c"""  # # # # #rc#HKt|}t|}|r|}|V|j|dD]G}|d|zr|dD]0}||vr*||||1H|}dSdS)zYield node for every successor of . Some successors may be unknown locally. This is a linear yield unsuited to detecting split changesets. It includes initial nodes too.r;r rN)rRrS successorsrTrU)r=r@rarbrZr[rcrds r allsuccessorsrhsE I y>>D  '--// '++GR88 ' 'DAw$ Aw ' 'd??HHSMMMMM#&&& '  ' ' ' ' 'rcd|DS)z"return a set with no prune markersc"h|] }|d | S)rr;.0rHs r z _filterprunes..s! ' ' '!!A$ 'A ' ' 'rr;rMs r _filterprunesrns ' 'w ' ' ''rc|}|jjj}|jj}|jj|jj}t}t|}fd|D}| t|}|rY| } t| | d}  | dD]} | ds| |  | | dD]} | ds| |  | D]} | |vr| ds | d| kr|| | d} | |vr=|| } | r| |vrOt | }||r*|| | | |Y|S)aset of markers relevant to "nodes" but no other locally-known nodes This function compute the set of markers "exclusive" to a locally-known node. This means we walk the markers starting from until we reach a locally-known precursors outside of . Element of with locally-known successors outside of are ignored (since their precursors markers are also relevant to these successors). For example: # (A0 rewritten as A1) # # A0 <-1- A1 # Marker "1" is exclusive to A1 or # (A0 rewritten as AX; AX rewritten as A1; AX is unknown locally) # # <-1- A0 <-2- AX <-3- A1 # Marker "2,3" are exclusive to A1 or # (A0 has unknown precursors, A0 rewritten as A1 and A2 (divergence)) # # <-2- A1 # Marker "2" is exclusive to A0,A1 # / # <-1- A0 # # <-3- A2 # Marker "3" is exclusive to A0,A2 # # in addition: # # Markers "2,3" are exclusive to A1,A2 # Markers "1,2,3" are exclusive to A0,A1,A2 See test/test-obsolete-bundle-strip.t for more examples. An example usage is strip. When stripping a changeset, we also want to strip the markers exclusive to this changeset. Otherwise we would have "dangling"" obsolescence markers from its precursors: Obsolescence markers marking a node as obsolete without any successors available locally. As for relevant markers, the prune markers for children will be followed. Of course, they will only be followed if the pruned children is locally-known. Since the prune markers are relevant to the pruned node. However, while prune markers are considered relevant to the parent of the pruned changesets, prune markers for locally-known changeset (with no successors) are considered exclusive to the pruned nodes. This allows to strip the prune markers (with the rest of the exclusive chain) alongside the pruned changesets. cZg|]'}t|d%|(S)r;)rnrT)rlnsuccessormarkerss r z$exclusivemarkers..s7 P P P1]3C3G3G23N3N%O%O PQ P P Prr;rr) unfiltered changelogindexhas_noder=rQrgchildrenrRsortrSlistrTrVrUrnissubset)rr@unfirwprecursorsmarkerschildrenmarkers exclmarkersrY seennodesr[rNrcr]known precmarkersrrs @rr>r>s6l ??  D~#,H 2}/m,O%%K JJE Q P P P P P PE JJLLLE I ,#))++(,,Wb99::$(("55 % %D7 %t$$$#''44 % %D7 %t$$$ # #D{"" Aw &$q'W,,%%%7Dy  HTNNE U** ((8(<( children or precursor -> successor relation. It is very similar to "descendant" but augmented with obsolescence information. Beware that possible obsolescence cycle may result if complex situation. s%ln::rGc6h|]}|Sr;noderlcs rrmzforeground..Ws 222!QVVXX222rc^g|]*}||+Sr;)mutablerrs rrszforeground..Xs-CCCAqyy{{CqvvxxCCCrc32K|]}| |VdSrr;)rlrqrws r zforeground..Zs0551!5Q555555rc6h|]}|Sr;rrs rrmzforeground..\s ) ) )AFFHH ) ) )r) rtrRr=rurvrwlenupdaterh)rr@ foregroundplensuccsrrrws @rrrDs  ??  DTXXh..//J } 8>'0*oo%%z??D22z222ECCCCCG LLt}g>> ? ? ?5555555ETXXh6677J *oo%% * )j ) ) ))rsef1r3 @s^branch$s ^.*-source$s ^.*_source$s^source$cV|dtfdtD S)zvCheck that the key of a meta item (extrakey, extravalue) does not match at least one of the blacklist pattern rc3BK|]}|VdSr)match)rlpatternmetakeys rrz%metanotblacklisted..s/GGg7==))GGGGGGr)any METABLACKLIST)metaitemrs @rmetanotblacklistedrs4qkGGGGGGGGGG GGrcg}|D]X}|ds|ds,|drd}||Y|S)z/Drop all information but the username and patchs# User#s@@s@@ ) splitlines startswithrV)hunk cleanhunklines r _prepare_hunkrs{I!!## ??9 % % #T__T-B-B #u%%    T " " " rcHt|d}||St|S)zreturn a cleaned up linesN)nextr)iterdiffliness r _getdifflinesrs) 4 E }   rctj|jddi}|j|}||}|j|}||}d\}}d||fvr,t|}t|}||krdSd||fv,dS)z|return True if both ctx introduce the "same diff" This is a first and basic implementation, with many shortcoming. sgitT)opts)rrNF) r diffalloptsruirrtrevdiffr) leftctxrightctxdiffoptsleftunfileftdiff rightunfi rightdiffleftrights r_cmpdiffrs #GLLNN$5~FFH}''))'++--8H}}(}++H))++HLLNN;IH--IKD% tUm # #X&&i(( 5==5 tUm # # 4rcd}|D]}||kr |tz}||kr |tz}||kr |t z}||kr |tz}||kr |tz}| }ttt|}| }ttt|}||kr |tz}t!||s |t"z}|S)zeFrom an obs-marker relation, compute what changed between the predecessor and the successor. r) description DESCCHANGEDuser USERCHANGEDr4 DATECHANGEDbranch BRANCHCHANGEDparents PARENTCHANGEDextraitemsrzfilterr METACHANGEDr DIFFCHANGED)sourcergeffects changectx changeextractxmeta sourceextrasrcmetas r geteffectflagrsG!#!#  " "f&8&8&:&: : : { "G >>  v{{}} , , { "G >>  v{{}} , , { "G      0 0 } $G     &.."2"2 2 2 } $G oo''--// v0+>>??llnn**,, v0+>>?? g   { "G ** # { "G Nrcb|du|dukrd}tj||jjj}|jj}|jj j }tj }||j }|d}|d} t} t} |D]} | d} || }| || vs|| kr"| |||||krHt|| pg|r| || S)zreturn the set of pre-existing revisions obsoleted by a transaction Either the transaction or changes item of the transaction (for hooks) must be provided, but not both. Ns.exactly one of tr and changes must be provideds obsmarkerss origrepolenr)r ProgrammingErrorrtrurvget_rev _phasecachephaser=rgrTr publicchangesrRrUr{)rtrretorevr succsmarkersr addedmarkers origrepolenseenrevs obsoletedrcrrs r getobsoletedrsG d 4(( =$Q''' OO   ' - 5E   "E=+/L ]F*=)L.)KuuHI  AweDkk ;#//SK-?-?  S 5s  v % %  ||D!!'R ( ( 1 1, ? ?  MM#    rcNeZdZdZfdZdZejdZdZ xZ S)_succszAsmall class to represent a successors with some metadata about itcntt|j|i|t|_dSr)superrrrRrN)rargskwargs __class__s rrz_succs.__init__ s4$fd$d5f555uu rc`t|}|j|_|Sr)rrNcopy)rnews rrz _succs.copy s'Tlll''))  rc t|Sr)rRrs r_setz _succs._sets4yyrc@|j|jSr)rr{r"s rcanmergez_succs.canmergesy!!%*---r) r7r8r9r:rrr propertycacherr __classcell__)rs@rrrs{KK  .......rrc|jj}|g}t|}|i}|rT|d}||vp |o ||ko||v}||vr)||n |r!||vrt |fg||<ng||<nt ||D]J} | dD]<} | |vr6| |vrg|| <|| || n=Hng} t ||D]} t } | j | | g} | dD]~} g}| D]s}|| D]h}| }|j |j |D]}||vr||||it|r|} | | g}g}td| Dtd}|D]g}|D]8}||r!|j |j n+9||||h||||<|T||S)a Return set of all latest successors of initial nodes The successors set of a changeset A are the group of revisions that succeed A. It succeeds A as a consistent whole, each revision being only a partial replacement. By default, the successors set contains non-obsolete changesets only, walking the obsolescence graph until reaching a leaf. If 'closest' is set to True, closest successors-sets are return (the obsolescence walk stops on known changesets). This function returns the full list of successor sets which is why it returns a list of tuples and not just a single tuple. Each tuple is a valid successors set. Note that (A,) may be a valid successors set for changeset A (see below). In most cases, a changeset A will have a single element (e.g. the changeset A is replaced by A') in its successors set. Though, it is also common for a changeset A to have no elements in its successor set (e.g. the changeset has been pruned). Therefore, the returned list of successors sets will be [(A',)] or [], respectively. When a changeset A is split into A' and B', however, it will result in a successors set containing more than a single element, i.e. [(A',B')]. Divergent changesets will result in multiple successors sets, i.e. [(A',), (A'')]. If a changeset A is not obsolete, then it will conceptually have no successors set. To distinguish this from a pruned changeset, the successor set will contain itself only, i.e. [(A,)]. Finally, final successors unknown locally are considered to be pruned (pruned: obsoleted without any successors). (Final: successors not affected by markers). The 'closest' mode respect the repoview filtering. For example, without filter it will stop at the first locally known changeset, with 'visible' filter it will stop on visible changesets). The optional `cache` parameter is a dictionary that may contains precomputed successors sets. It is meant to reuse the computation of a previous call to `successorssets` when multiple calls are made at the same time. The cache dictionary is updated in place. The caller is responsible for its life span. Code that makes multiple calls to `successorssets` *should* use this cache mechanism or risk a performance hit. Since results are different depending of the 'closest' most, the same cache cannot be reused for both mode. NrGrc3K|]}||V dSrr;)rlss rrz!successorssets..s'//1Q/Q//////rT)rJreverse)r=rgrRremoverSrrOrVrUrNrrextendrLrrr)r initialnodeclosestcache succmarkers toproceed stackedsetr[case2conditionrcrd succssetsbasemarkss productresultprefixsuffixnewsspartrZfinal candidatescand seensuccss rsuccessorssetsr s^b-*K IYJ }8 O'$B-"4  B;. B7d?  e     immoo . . . . r '$"('"4"4!5g"$gB&k'&:;;I 'I '7C%''*,,)+E#JJ &,,S111&NN3///!E(( )+g*>??--D!88DL$$T***"VF#Aw33(* &, < >t 4T : : :E {{ }'H33  3  $ $T * * * *H SXXZZ44 3 3Aw3#H!88DL$$T***%,,T222 3!((222 F!GG d EEFFFF Mrct|dkrdSt|dkrdS|d}t|dkrdSdS)a}Compute a changeset obsolescence fate based on its successorssets. Successors can be the tipmost ones or the immediate ones. This function return values are not meant to be shown directly to users, it is meant to be used by internal functions only. Returns one fate from the following values: - pruned - diverged - superseded - superseded_split rprunedrdiverged supersededsuperseded_splitr)r rgs r _getobsfater3s\ >ay ^  q {$A& z??a   =&&rc@|sd}nt|dkrd}nd}|S)zhReturn the verb summarizing the successorset and potentially using information from the markers rrs rewrittenssplitr) successorsetrNverbs r obsfateverbr"Ns7  \  a   Krcd|DS)z/returns the list of dates for a list of markerscg|] }|d S)r3r;rks rrsz markersdates..]s " " "QAaD " " "rr;rMs r markersdatesr%[s " "' " " ""rcPd|D}d|D}t|S)z9Returns a sorted list of markers users without duplicatesc8g|]}t|dSr/r0rks rrsz markersusers..b"///!4!::///rclh|]1}|dtj|d2S)suser)rTrtolocalrlmetas rrmzmarkersusers..csI     88G   g''   rrK)rN markersmetauserss r markersusersr1`sA//w///K     E %==rcPd|D}d|D}t|S)z>Returns a sorted list of markers operations without duplicatesc8g|]}t|dSr(r)rks rrsz%markersoperations..nr*rcbh|],}|d|d-S)s operation)rTr-s rrmz$markersoperations..osE#'$((<:P:P rrK)rNr/ operationss rmarkersoperationsr6lsC//w///K+6J *  rc|j}|j}| o| }g}|t||t |} | r+|dd| z|r:fd|D} |dd| zt |} |s/|d} t| dkr| | vrd} |s|r-| r+|d d| zt|} | r|rt| }t| }||kr.tj |d }|d |znDtj |d }tj |d }|d ||fzd |S)zoBuild a obsfate string for a single successorset using all obsfate related function defined in obsutil s using %s, c2g|]}|Sr;r;)rlsucc formatctxrs rrsz"obsfateprinter..s'FFF44:..FFFrs as %sT) acceptemptyrNs by %ss%Y-%m-%d %H:%M %1%2s (at %s)s (between %s and %s)r)quietverboserVr"r6joinr1usernamerr%minmaxr datestr)rrrgrNr;r=r>normalrr5 fmtsuccessorsr0 currentuserdatesmin_datemax_date fmtmin_date fmtmax_dates ` ` robsfateprinterrLvs  HEjG[ &YF D KK J00111#7++J; L5::j#9#99:::;FFFFF:FFF  I = 9 99:::  ! !E kkdk33 u::??{e33E363u3 I 5 1 11222  ! !E N Nu::u:: x  "*85KLLK KK k1 2 2 2 2"*85KLLK"*85KLLK KK/; 2LL M M M 88D>>rshidden revision '%s' is pruneds!hidden revision '%s' has divergeds)hidden revision '%s' was rewritten as: %ss%hidden revision '%s' was split as: %ss1hidden revision '%s' was split as: %s and %d more)rrrrsuperseded_split_severalct||}t|}|dkrtd|zS|dkrtd|zS|dkr-t |dd}td||fzS|dkrg}|dD]$}|t |%t |dkr'd|}td||fzSd|dd} t |dz } || | f} td | zSdS) zDreturn a human-friendly string on why a obsolete changeset is hiddenrrrrrr r8NrM)r rrfilteredmsgtablerrVrr?) rchangeidrrgfatesingle_successorrnode_idfmtsuccsfirstsuccessorsremainingnumberrs r_getfilteredreasonrWsXchhjj11J z " "D y *X55    ,x77    Aq!122 .(md|DS)z2Compute sets of commits divergent with a given onecg|] \}}||d S))divergentnodescommonpredecessorr;)rldivsetbs rrsz!divergentsets..s4    FA#!<<   r)rer=rr tupler)rrrrrq nsuccsetsnsuccsets r divergentsetsras E D T]SXXZZL 9 9 & &  ?? "4E22 ! & &HxxzzX%%X$&&$%Dx ! ! &     rc g}|rv|D]a}d}|rd}n|rd}|.|dd|z|db|rmt j|gt}fd|D}|D]-}|dd|d.| rVt|}|D]C} fd | d D} |d | d t | d dD|S)Nsorphansobsoletes %s parent) instabilityreasonnode)rac\g|](}|v| |)Sr;)r)rlprs rrszwhyunstable..s;   Q$YYtAw?P?PYDGYYYrsphase-divergentsimmutable predecessorc g|] }| Sr;r;)rlrqrs rrszwhyunstable..sAAAAQAAArrZscontent-divergents predecessorr[)rcrZrdre) orphanrrrVrphasedivergentrer=r bumpedfixcontentdivergentra) rrresultparentkindrQ immutable predecessordsetsdsetdivnodess ` r whyunstablerus F zz||kkmm  FD}} # "" #" (1#/$#6!' & MCHHJJrEFFECTFLAGFIELDrrrrrrrcompilerrrrrrrrzrr rrr"r%r1r6rLrOrWrarur;rrr}s} @   ''''''''T ' ' ' ' BBB ))):####0'''',((( wwwt***T       BJ{BJ~BJ~BJ{  HHH   8)))X@.....T...*eeeeP---`'''6   ###   222lq2337881ABBCDD!"<"" HHH<.,,,,,r