0000: 23 23 20 2d 2a 2d 20 74 63 6c 20 2d 2a 2d 0a 23 ## -*- tcl -*-.#
0010: 20 23 20 23 23 20 23 23 23 20 23 23 23 23 23 20 # ## ### #####
0020: 23 23 23 23 23 23 23 23 20 23 23 23 23 23 23 23 ######## #######
0030: 23 23 23 23 23 23 20 23 23 23 23 23 23 23 23 23 ###### #########
0040: 23 23 23 23 23 23 23 23 23 23 23 23 0a 23 23 20 ############.##
0050: 43 6f 70 79 72 69 67 68 74 20 28 63 29 20 32 30 Copyright (c) 20
0060: 30 37 20 41 6e 64 72 65 61 73 20 4b 75 70 72 69 07 Andreas Kupri
0070: 65 73 2e 0a 23 0a 23 20 54 68 69 73 20 73 6f 66 es..#.# This sof
0080: 74 77 61 72 65 20 69 73 20 6c 69 63 65 6e 73 65 tware is license
0090: 64 20 61 73 20 64 65 73 63 72 69 62 65 64 20 69 d as described i
00a0: 6e 20 74 68 65 20 66 69 6c 65 20 4c 49 43 45 4e n the file LICEN
00b0: 53 45 2c 20 77 68 69 63 68 0a 23 20 79 6f 75 20 SE, which.# you
00c0: 73 68 6f 75 6c 64 20 68 61 76 65 20 72 65 63 65 should have rece
00d0: 69 76 65 64 20 61 73 20 70 61 72 74 20 6f 66 20 ived as part of
00e0: 74 68 69 73 20 64 69 73 74 72 69 62 75 74 69 6f this distributio
00f0: 6e 2e 0a 23 0a 23 20 54 68 69 73 20 73 6f 66 74 n..#.# This soft
0100: 77 61 72 65 20 63 6f 6e 73 69 73 74 73 20 6f 66 ware consists of
0110: 20 76 6f 6c 75 6e 74 61 72 79 20 63 6f 6e 74 72 voluntary contr
0120: 69 62 75 74 69 6f 6e 73 20 6d 61 64 65 20 62 79 ibutions made by
0130: 20 6d 61 6e 79 0a 23 20 69 6e 64 69 76 69 64 75 many.# individu
0140: 61 6c 73 2e 20 20 46 6f 72 20 65 78 61 63 74 20 als. For exact
0150: 63 6f 6e 74 72 69 62 75 74 69 6f 6e 20 68 69 73 contribution his
0160: 74 6f 72 79 2c 20 73 65 65 20 74 68 65 20 72 65 tory, see the re
0170: 76 69 73 69 6f 6e 0a 23 20 68 69 73 74 6f 72 79 vision.# history
0180: 20 61 6e 64 20 6c 6f 67 73 2c 20 61 76 61 69 6c and logs, avail
0190: 61 62 6c 65 20 61 74 20 68 74 74 70 3a 2f 2f 66 able at http://f
01a0: 6f 73 73 69 6c 2d 73 63 6d 2e 68 77 61 63 69 2e ossil-scm.hwaci.
01b0: 63 6f 6d 2f 66 6f 73 73 69 6c 0a 23 20 23 20 23 com/fossil.# # #
01c0: 23 20 23 23 23 20 23 23 23 23 23 20 23 23 23 23 # ### ##### ####
01d0: 23 23 23 23 20 23 23 23 23 23 23 23 23 23 23 23 #### ###########
01e0: 23 23 20 23 23 23 23 23 23 23 23 23 23 23 23 23 ## #############
01f0: 23 23 23 23 23 23 23 23 0a 0a 23 23 20 52 65 76 ########..## Rev
0200: 69 73 69 6f 6e 73 20 70 65 72 20 70 72 6f 6a 65 isions per proje
0210: 63 74 2c 20 61 6b 61 20 43 68 61 6e 67 65 73 65 ct, aka Changese
0220: 74 73 2e 20 54 68 65 73 65 20 6f 62 6a 65 63 74 ts. These object
0230: 73 20 61 72 65 20 66 69 72 73 74 20 75 73 65 64 s are first used
0240: 0a 23 23 20 69 6e 20 70 61 73 73 20 35 2c 20 77 .## in pass 5, w
0250: 68 69 63 68 20 63 72 65 61 74 65 73 20 74 68 65 hich creates the
0260: 20 69 6e 69 74 69 61 6c 20 73 65 74 20 63 6f 76 initial set cov
0270: 65 72 69 6e 67 20 74 68 65 20 72 65 70 6f 73 69 ering the reposi
0280: 74 6f 72 79 2e 0a 0a 23 20 23 20 23 23 20 23 23 tory...# # ## ##
0290: 23 20 23 23 23 23 23 20 23 23 23 23 23 23 23 23 # ##### ########
02a0: 20 23 23 23 23 23 23 23 23 23 23 23 23 23 20 23 ############# #
02b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 ################
02c0: 23 23 23 23 0a 23 23 20 52 65 71 75 69 72 65 6d ####.## Requirem
02d0: 65 6e 74 73 0a 0a 70 61 63 6b 61 67 65 20 72 65 ents..package re
02e0: 71 75 69 72 65 20 54 63 6c 20 38 2e 34 20 20 20 quire Tcl 8.4
02f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0300: 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 23 20 ; #
0310: 52 65 71 75 69 72 65 64 20 72 75 6e 74 69 6d 65 Required runtime
0320: 2e 0a 70 61 63 6b 61 67 65 20 72 65 71 75 69 72 ..package requir
0330: 65 20 73 6e 69 74 20 20 20 20 20 20 20 20 20 20 e snit
0340: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0350: 20 20 20 20 20 20 20 20 3b 20 23 20 4f 4f 20 73 ; # OO s
0360: 79 73 74 65 6d 2e 0a 70 61 63 6b 61 67 65 20 72 ystem..package r
0370: 65 71 75 69 72 65 20 73 74 72 75 63 74 3a 3a 73 equire struct::s
0380: 65 74 20 20 20 20 20 20 20 20 20 20 20 20 20 20 et
0390: 20 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 23 ; #
03a0: 20 53 65 74 20 6f 70 65 72 61 74 69 6f 6e 73 2e Set operations.
03b0: 0a 70 61 63 6b 61 67 65 20 72 65 71 75 69 72 65 .package require
03c0: 20 76 63 3a 3a 74 6f 6f 6c 73 3a 3a 6d 69 73 63 vc::tools::misc
03d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
03e0: 20 20 20 20 20 20 20 3b 20 23 20 54 65 78 74 20 ; # Text
03f0: 66 6f 72 6d 61 74 74 69 6e 67 0a 70 61 63 6b 61 formatting.packa
0400: 67 65 20 72 65 71 75 69 72 65 20 76 63 3a 3a 74 ge require vc::t
0410: 6f 6f 6c 73 3a 3a 74 72 6f 75 62 6c 65 20 20 20 ools::trouble
0420: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
0430: 20 3b 20 23 20 45 72 72 6f 72 20 72 65 70 6f 72 ; # Error repor
0440: 74 69 6e 67 2e 0a 70 61 63 6b 61 67 65 20 72 65 ting..package re
0450: 71 75 69 72 65 20 76 63 3a 3a 74 6f 6f 6c 73 3a quire vc::tools:
0460: 3a 6c 6f 67 20 20 20 20 20 20 20 20 20 20 20 20 :log
0470: 20 20 20 20 20 20 20 20 20 20 20 20 3b 20 23 20 ; #
0480: 55 73 65 72 20 66 65 65 64 62 61 63 6b 2e 0a 70 User feedback..p
0490: 61 63 6b 61 67 65 20 72 65 71 75 69 72 65 20 76 ackage require v
04a0: 63 3a 3a 66 6f 73 73 69 6c 3a 3a 69 6d 70 6f 72 c::fossil::impor
04b0: 74 3a 3a 63 76 73 3a 3a 73 74 61 74 65 20 20 20 t::cvs::state
04c0: 20 20 20 20 20 3b 20 23 20 53 74 61 74 65 20 73 ; # State s
04d0: 74 6f 72 61 67 65 2e 0a 70 61 63 6b 61 67 65 20 torage..package
04e0: 72 65 71 75 69 72 65 20 76 63 3a 3a 66 6f 73 73 require vc::foss
04f0: 69 6c 3a 3a 69 6d 70 6f 72 74 3a 3a 63 76 73 3a il::import::cvs:
0500: 3a 69 6e 74 65 67 72 69 74 79 20 20 20 20 3b 20 :integrity ;
0510: 23 20 53 74 61 74 65 20 69 6e 74 65 67 72 69 74 # State integrit
0520: 79 20 63 68 65 63 6b 73 2e 0a 0a 23 20 23 20 23 y checks...# # #
0530: 23 20 23 23 23 20 23 23 23 23 23 20 23 23 23 23 # ### ##### ####
0540: 23 23 23 23 20 23 23 23 23 23 23 23 23 23 23 23 #### ###########
0550: 23 23 20 23 23 23 23 23 23 23 23 23 23 23 23 23 ## #############
0560: 23 23 23 23 23 23 23 23 0a 23 23 0a 0a 73 6e 69 ########.##..sni
0570: 74 3a 3a 74 79 70 65 20 3a 3a 76 63 3a 3a 66 6f t::type ::vc::fo
0580: 73 73 69 6c 3a 3a 69 6d 70 6f 72 74 3a 3a 63 76 ssil::import::cv
0590: 73 3a 3a 70 72 6f 6a 65 63 74 3a 3a 72 65 76 20 s::project::rev
05a0: 7b 0a 20 20 20 20 23 20 23 20 23 23 20 23 23 23 {. # # ## ###
05b0: 20 23 23 23 23 23 20 23 23 23 23 23 23 23 23 20 ##### ########
05c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 0a 20 20 #############.
05d0: 20 20 23 23 20 50 75 62 6c 69 63 20 41 50 49 0a ## Public API.
05e0: 0a 20 20 20 20 63 6f 6e 73 74 72 75 63 74 6f 72 . constructor
05f0: 20 7b 70 72 6f 6a 65 63 74 20 63 73 74 79 70 65 {project cstype
0600: 20 73 72 63 69 64 20 69 74 65 6d 73 20 7b 74 68 srcid items {th
0610: 65 69 64 20 7b 7d 7d 7d 20 7b 0a 09 69 66 20 7b eid {}}} {..if {
0620: 24 74 68 65 69 64 20 6e 65 20 22 22 7d 20 7b 0a $theid ne ""} {.
0630: 09 20 20 20 20 73 65 74 20 6d 79 69 64 20 24 74 . set myid $t
0640: 68 65 69 64 0a 09 7d 20 65 6c 73 65 20 7b 0a 09 heid..} else {..
0650: 20 20 20 20 73 65 74 20 6d 79 69 64 20 5b 69 6e set myid [in
0660: 63 72 20 6d 79 63 6f 75 6e 74 65 72 5d 0a 09 7d cr mycounter]..}
0670: 0a 0a 09 69 6e 74 65 67 72 69 74 79 20 61 73 73 ...integrity ass
0680: 65 72 74 20 7b 0a 09 20 20 20 20 5b 69 6e 66 6f ert {.. [info
0690: 20 65 78 69 73 74 73 20 6d 79 63 73 74 79 70 65 exists mycstype
06a0: 28 24 63 73 74 79 70 65 29 5d 0a 09 7d 20 7b 42 ($cstype)]..} {B
06b0: 61 64 20 63 68 61 6e 67 65 73 65 74 20 74 79 70 ad changeset typ
06c0: 65 20 27 24 63 73 74 79 70 65 27 2e 7d 0a 0a 09 e '$cstype'.}...
06d0: 73 65 74 20 6d 79 70 72 6f 6a 65 63 74 20 20 20 set myproject
06e0: 24 70 72 6f 6a 65 63 74 0a 09 73 65 74 20 6d 79 $project..set my
06f0: 74 79 70 65 20 20 20 20 20 20 24 63 73 74 79 70 type $cstyp
0700: 65 0a 09 73 65 74 20 6d 79 74 79 70 65 6f 62 6a e..set mytypeobj
0710: 20 20 20 3a 3a 76 63 3a 3a 66 6f 73 73 69 6c 3a ::vc::fossil:
0720: 3a 69 6d 70 6f 72 74 3a 3a 63 76 73 3a 3a 70 72 :import::cvs::pr
0730: 6f 6a 65 63 74 3a 3a 72 65 76 3a 3a 24 7b 63 73 oject::rev::${cs
0740: 74 79 70 65 7d 0a 09 73 65 74 20 6d 79 73 72 63 type}..set mysrc
0750: 69 64 09 24 73 72 63 69 64 0a 09 73 65 74 20 6d id.$srcid..set m
0760: 79 69 74 65 6d 73 20 20 20 20 20 24 69 74 65 6d yitems $item
0770: 73 0a 09 73 65 74 20 6d 79 70 6f 73 20 20 20 20 s..set mypos
0780: 20 20 20 7b 7d 20 3b 20 23 20 43 6f 6d 6d 69 74 {} ; # Commit
0790: 20 6c 6f 63 61 74 69 6f 6e 20 69 73 20 6e 6f 74 location is not
07a0: 20 6b 6e 6f 77 6e 20 79 65 74 2e 0a 0a 09 23 20 known yet....#
07b0: 4b 65 65 70 20 74 72 61 63 6b 20 6f 66 20 74 68 Keep track of th
07c0: 65 20 67 65 6e 65 72 61 74 65 64 20 63 68 61 6e e generated chan
07d0: 67 65 73 65 74 73 20 61 6e 64 20 6f 66 20 74 68 gesets and of th
07e0: 65 20 69 6e 76 65 72 73 65 0a 09 23 20 6d 61 70 e inverse..# map
07f0: 70 69 6e 67 20 66 72 6f 6d 20 69 74 65 6d 73 20 ping from items
0800: 74 6f 20 74 68 65 6d 2e 0a 09 6c 61 70 70 65 6e to them...lappen
0810: 64 20 6d 79 63 68 61 6e 67 65 73 65 74 73 20 20 d mychangesets
0820: 20 24 73 65 6c 66 0a 09 6c 61 70 70 65 6e 64 20 $self..lappend
0830: 6d 79 74 63 68 61 6e 67 65 73 65 74 73 28 24 63 mytchangesets($c
0840: 73 74 79 70 65 29 20 24 73 65 6c 66 0a 09 73 65 stype) $self..se
0850: 74 20 20 20 20 20 6d 79 69 64 6d 61 70 28 24 6d t myidmap($m
0860: 79 69 64 29 20 24 73 65 6c 66 0a 09 66 6f 72 65 yid) $self..fore
0870: 61 63 68 20 69 69 64 20 24 69 74 65 6d 73 20 7b ach iid $items {
0880: 0a 09 20 20 20 20 73 65 74 20 6b 65 79 20 5b 6c .. set key [l
0890: 69 73 74 20 24 63 73 74 79 70 65 20 24 69 69 64 ist $cstype $iid
08a0: 5d 0a 09 20 20 20 20 73 65 74 20 6d 79 69 74 65 ].. set myite
08b0: 6d 6d 61 70 28 24 6b 65 79 29 20 24 73 65 6c 66 mmap($key) $self
08c0: 0a 09 20 20 20 20 6c 61 70 70 65 6e 64 20 6d 79 .. lappend my
08d0: 74 69 74 65 6d 73 20 24 6b 65 79 0a 09 20 20 20 titems $key..
08e0: 20 6c 6f 67 20 77 72 69 74 65 20 38 20 63 73 65 log write 8 cse
08f0: 74 73 20 7b 4d 41 50 2b 20 69 74 65 6d 20 3c 24 ts {MAP+ item <$
0900: 6b 65 79 3e 20 24 73 65 6c 66 20 3d 20 5b 24 73 key> $self = [$s
0910: 65 6c 66 20 73 74 72 5d 7d 0a 09 7d 0a 09 72 65 elf str]}..}..re
0920: 74 75 72 6e 0a 20 20 20 20 7d 0a 0a 20 20 20 20 turn. }..
0930: 6d 65 74 68 6f 64 20 73 74 72 20 7b 7d 20 7b 0a method str {} {.
0940: 09 73 65 74 20 73 74 72 20 20 20 20 22 3c 22 0a .set str "<".
0950: 09 73 65 74 20 64 65 74 61 69 6c 20 22 22 0a 09 .set detail ""..
0960: 69 66 20 7b 5b 24 6d 79 74 79 70 65 6f 62 6a 20 if {[$mytypeobj
0970: 62 79 73 79 6d 62 6f 6c 5d 7d 20 7b 0a 09 20 20 bysymbol]} {..
0980: 20 20 73 65 74 20 64 65 74 61 69 6c 20 22 20 27 set detail " '
0990: 5b 73 74 61 74 65 20 6f 6e 65 20 7b 0a 09 09 53 [state one {...S
09a0: 45 4c 45 43 54 20 53 2e 6e 61 6d 65 0a 09 09 46 ELECT S.name...F
09b0: 52 4f 4d 20 20 20 73 79 6d 62 6f 6c 20 53 0a 09 ROM symbol S..
09c0: 09 57 48 45 52 45 20 20 53 2e 73 69 64 20 3d 20 .WHERE S.sid =
09d0: 24 6d 79 73 72 63 69 64 0a 09 20 20 20 20 7d 5d $mysrcid.. }]
09e0: 27 22 0a 09 7d 0a 09 61 70 70 65 6e 64 20 73 74 '"..}..append st
09f0: 72 20 22 24 6d 79 74 79 70 65 20 24 7b 6d 79 69 r "$mytype ${myi
0a00: 64 7d 24 7b 64 65 74 61 69 6c 7d 3e 22 0a 09 72 d}${detail}>"..r
0a10: 65 74 75 72 6e 20 24 73 74 72 0a 20 20 20 20 7d eturn $str. }
0a20: 0a 0a 20 20 20 20 6d 65 74 68 6f 64 20 69 64 20 .. method id
0a30: 20 20 20 7b 7d 20 7b 20 72 65 74 75 72 6e 20 24 {} { return $
0a40: 6d 79 69 64 20 7d 0a 20 20 20 20 6d 65 74 68 6f myid }. metho
0a50: 64 20 69 74 65 6d 73 20 7b 7d 20 7b 20 72 65 74 d items {} { ret
0a60: 75 72 6e 20 24 6d 79 74 69 74 65 6d 73 20 7d 0a urn $mytitems }.
0a70: 20 20 20 20 6d 65 74 68 6f 64 20 64 61 74 61 20 method data
0a80: 20 7b 7d 20 7b 20 72 65 74 75 72 6e 20 5b 6c 69 {} { return [li
0a90: 73 74 20 24 6d 79 70 72 6f 6a 65 63 74 20 24 6d st $myproject $m
0aa0: 79 74 79 70 65 20 24 6d 79 73 72 63 69 64 5d 20 ytype $mysrcid]
0ab0: 7d 0a 0a 20 20 20 20 64 65 6c 65 67 61 74 65 20 }.. delegate
0ac0: 6d 65 74 68 6f 64 20 62 79 73 79 6d 62 6f 6c 20 method bysymbol
0ad0: 20 20 74 6f 20 6d 79 74 79 70 65 6f 62 6a 0a 20 to mytypeobj.
0ae0: 20 20 20 64 65 6c 65 67 61 74 65 20 6d 65 74 68 delegate meth
0af0: 6f 64 20 62 79 72 65 76 69 73 69 6f 6e 20 74 6f od byrevision to
0b00: 20 6d 79 74 79 70 65 6f 62 6a 0a 20 20 20 20 64 mytypeobj. d
0b10: 65 6c 65 67 61 74 65 20 6d 65 74 68 6f 64 20 69 elegate method i
0b20: 73 62 72 61 6e 63 68 20 20 20 74 6f 20 6d 79 74 sbranch to myt
0b30: 79 70 65 6f 62 6a 0a 20 20 20 20 64 65 6c 65 67 ypeobj. deleg
0b40: 61 74 65 20 6d 65 74 68 6f 64 20 69 73 74 61 67 ate method istag
0b50: 20 20 20 20 20 20 74 6f 20 6d 79 74 79 70 65 6f to mytypeo
0b60: 62 6a 0a 0a 20 20 20 20 6d 65 74 68 6f 64 20 73 bj.. method s
0b70: 65 74 70 6f 73 20 7b 70 7d 20 7b 20 73 65 74 20 etpos {p} { set
0b80: 6d 79 70 6f 73 20 24 70 20 3b 20 72 65 74 75 72 mypos $p ; retur
0b90: 6e 20 7d 0a 20 20 20 20 6d 65 74 68 6f 64 20 70 n }. method p
0ba0: 6f 73 20 20 20 20 7b 7d 20 20 7b 20 72 65 74 75 os {} { retu
0bb0: 72 6e 20 24 6d 79 70 6f 73 20 7d 0a 0a 20 20 20 rn $mypos }..
0bc0: 20 6d 65 74 68 6f 64 20 64 65 74 65 72 6d 69 6e method determin
0bd0: 65 73 75 63 63 65 73 73 6f 72 73 20 7b 7d 20 7b esuccessors {} {
0be0: 0a 09 23 20 50 61 73 73 20 36 20 6f 70 65 72 61 ..# Pass 6 opera
0bf0: 74 69 6f 6e 2e 20 43 6f 6d 70 75 74 65 20 70 72 tion. Compute pr
0c00: 6f 6a 65 63 74 2d 6c 65 76 65 6c 20 64 65 70 65 oject-level depe
0c10: 6e 64 65 6e 63 69 65 73 20 66 72 6f 6d 0a 09 23 ndencies from..#
0c20: 20 74 68 65 20 66 69 6c 65 2d 6c 65 76 65 6c 20 the file-level
0c30: 64 61 74 61 20 61 6e 64 20 73 61 76 65 20 69 74 data and save it
0c40: 20 62 61 63 6b 20 74 6f 20 74 68 65 20 73 74 61 back to the sta
0c50: 74 65 2e 20 54 68 69 73 20 6d 61 79 0a 09 23 20 te. This may..#
0c60: 62 65 20 63 61 6c 6c 65 64 20 64 75 72 69 6e 67 be called during
0c70: 20 74 68 65 20 63 79 63 6c 65 20 62 72 65 61 6b the cycle break
0c80: 65 72 20 70 61 73 73 65 73 20 61 73 20 77 65 6c er passes as wel
0c90: 6c 2c 20 74 6f 20 61 64 6a 75 73 74 0a 09 23 20 l, to adjust..#
0ca0: 74 68 65 20 73 75 63 63 65 73 73 6f 72 20 69 6e the successor in
0cb0: 66 6f 72 6d 61 74 69 6f 6e 20 6f 66 20 63 68 61 formation of cha
0cc0: 6e 67 65 73 65 74 73 20 77 68 69 63 68 20 61 72 ngesets which ar
0cd0: 65 20 74 68 65 0a 09 23 20 70 72 65 64 65 63 65 e the..# predece
0ce0: 73 73 6f 72 73 20 6f 66 20 64 72 6f 70 70 65 64 ssors of dropped
0cf0: 20 63 68 61 6e 67 65 73 65 74 73 2e 20 46 6f 72 changesets. For
0d00: 20 74 68 65 6d 20 77 65 20 68 61 76 65 20 74 6f them we have to
0d10: 0a 09 23 20 72 65 6d 6f 76 65 20 74 68 65 69 72 ..# remove their
0d20: 20 65 78 69 73 74 69 6e 67 20 69 6e 66 6f 72 6d existing inform
0d30: 61 74 69 6f 6e 20 66 69 72 73 74 20 62 65 66 6f ation first befo
0d40: 72 65 20 69 6e 73 65 72 74 69 6e 67 20 74 68 65 re inserting the
0d50: 0a 09 23 20 6e 65 77 20 64 61 74 61 2e 0a 09 73 ..# new data...s
0d60: 74 61 74 65 20 72 75 6e 20 7b 0a 09 20 20 20 20 tate run {..
0d70: 44 45 4c 45 54 45 20 46 52 4f 4d 20 63 73 73 75 DELETE FROM cssu
0d80: 63 63 65 73 73 6f 72 20 57 48 45 52 45 20 63 69 ccessor WHERE ci
0d90: 64 20 3d 20 24 6d 79 69 64 3b 0a 09 7d 0a 09 73 d = $myid;..}..s
0da0: 65 74 20 6c 6f 6f 70 20 30 0a 09 66 6f 72 65 61 et loop 0..forea
0db0: 63 68 20 6e 69 64 20 5b 24 6d 79 74 79 70 65 6f ch nid [$mytypeo
0dc0: 62 6a 20 63 73 5f 73 75 63 63 65 73 73 6f 72 73 bj cs_successors
0dd0: 20 24 6d 79 69 74 65 6d 73 5d 20 7b 0a 09 20 20 $myitems] {..
0de0: 20 20 73 74 61 74 65 20 72 75 6e 20 7b 0a 09 09 state run {...
0df0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 73 73 75 INSERT INTO cssu
0e00: 63 63 65 73 73 6f 72 20 28 63 69 64 2c 20 20 6e ccessor (cid, n
0e10: 69 64 29 0a 09 09 56 41 4c 55 45 53 20 20 20 20 id)...VALUES
0e20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 28 24 ($
0e30: 6d 79 69 64 2c 24 6e 69 64 29 0a 09 20 20 20 20 myid,$nid)..
0e40: 7d 0a 09 20 20 20 20 69 66 20 7b 24 6e 69 64 20 }.. if {$nid
0e50: 3d 3d 20 24 6d 79 69 64 7d 20 7b 20 73 65 74 20 == $myid} { set
0e60: 6c 6f 6f 70 20 31 20 7d 0a 09 7d 0a 09 23 20 52 loop 1 }..}..# R
0e70: 65 70 6f 72 74 20 61 66 74 65 72 20 74 68 65 20 eport after the
0e80: 63 6f 6d 70 6c 65 74 65 20 73 74 72 75 63 74 75 complete structu
0e90: 72 65 20 68 61 73 20 62 65 65 6e 20 73 61 76 65 re has been save
0ea0: 64 2e 0a 09 69 66 20 7b 24 6c 6f 6f 70 7d 20 7b d...if {$loop} {
0eb0: 20 24 73 65 6c 66 20 72 65 70 6f 72 74 6c 6f 6f $self reportloo
0ec0: 70 20 7d 0a 09 72 65 74 75 72 6e 0a 20 20 20 20 p }..return.
0ed0: 7d 0a 0a 20 20 20 20 23 20 72 65 73 75 6c 74 20 }.. # result
0ee0: 3d 20 6c 69 73 74 20 28 63 68 61 6e 67 65 73 65 = list (changese
0ef0: 74 29 0a 20 20 20 20 6d 65 74 68 6f 64 20 73 75 t). method su
0f00: 63 63 65 73 73 6f 72 73 20 7b 7d 20 7b 0a 09 23 ccessors {} {..#
0f10: 20 55 73 65 20 74 68 65 20 64 61 74 61 20 73 61 Use the data sa
0f20: 76 65 64 20 62 79 20 70 61 73 73 20 36 2e 0a 09 ved by pass 6...
0f30: 72 65 74 75 72 6e 20 5b 73 74 72 75 63 74 3a 3a return [struct::
0f40: 6c 69 73 74 20 6d 61 70 20 5b 73 74 61 74 65 20 list map [state
0f50: 72 75 6e 20 7b 0a 09 20 20 20 20 53 45 4c 45 43 run {.. SELEC
0f60: 54 20 53 2e 6e 69 64 0a 09 20 20 20 20 46 52 4f T S.nid.. FRO
0f70: 4d 20 20 20 63 73 73 75 63 63 65 73 73 6f 72 20 M cssuccessor
0f80: 53 0a 09 20 20 20 20 57 48 45 52 45 20 20 53 2e S.. WHERE S.
0f90: 63 69 64 20 3d 20 24 6d 79 69 64 0a 09 7d 5d 20 cid = $myid..}]
0fa0: 5b 6d 79 74 79 70 65 6d 65 74 68 6f 64 20 6f 66 [mytypemethod of
0fb0: 5d 5d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 23 20 ]]. }.. #
0fc0: 69 74 65 6d 20 2d 3e 20 6c 69 73 74 20 28 69 74 item -> list (it
0fd0: 65 6d 29 0a 20 20 20 20 6d 65 74 68 6f 64 20 6e em). method n
0fe0: 65 78 74 6d 61 70 20 7b 7d 20 7b 0a 09 24 6d 79 extmap {} {..$my
0ff0: 74 79 70 65 6f 62 6a 20 73 75 63 63 65 73 73 6f typeobj successo
1000: 72 73 20 74 6d 70 20 24 6d 79 69 74 65 6d 73 0a rs tmp $myitems.
1010: 09 72 65 74 75 72 6e 20 5b 61 72 72 61 79 20 67 .return [array g
1020: 65 74 20 74 6d 70 5d 0a 20 20 20 20 7d 0a 0a 20 et tmp]. }..
1030: 20 20 20 6d 65 74 68 6f 64 20 62 72 65 61 6b 69 method breaki
1040: 6e 74 65 72 6e 61 6c 64 65 70 65 6e 64 65 6e 63 nternaldependenc
1050: 69 65 73 20 7b 7d 20 7b 0a 0a 09 23 23 0a 09 23 ies {} {...##..#
1060: 23 20 4e 4f 54 45 3a 20 54 68 69 73 20 6d 65 74 # NOTE: This met
1070: 68 6f 64 2c 20 6d 61 79 62 65 20 69 6e 20 63 6f hod, maybe in co
1080: 6e 6a 75 6e 63 74 69 6f 6e 20 77 69 74 68 20 69 njunction with i
1090: 74 73 20 63 61 6c 6c 65 72 0a 09 23 23 20 20 20 ts caller..##
10a0: 20 20 20 20 73 65 65 6d 73 20 74 6f 20 62 65 20 seems to be
10b0: 61 20 6d 65 6d 6f 72 79 20 68 6f 67 2c 20 65 73 a memory hog, es
10c0: 70 65 63 69 61 6c 6c 79 20 66 6f 72 20 6c 61 72 pecially for lar
10d0: 67 65 0a 09 23 23 20 20 20 20 20 20 20 63 68 61 ge..## cha
10e0: 6e 67 65 73 65 74 73 2c 20 77 69 74 68 20 27 6c ngesets, with 'l
10f0: 61 72 67 65 27 20 6d 65 61 6e 69 6e 67 20 74 6f arge' meaning to
1100: 20 68 61 76 65 20 61 20 27 6c 6f 6e 67 20 6c 69 have a 'long li
1110: 73 74 0a 09 23 23 20 20 20 20 20 20 20 6f 66 20 st..## of
1120: 69 74 65 6d 73 2c 20 73 65 76 65 72 61 6c 20 74 items, several t
1130: 68 6f 75 73 61 6e 64 27 2e 20 49 6e 76 65 73 74 housand'. Invest
1140: 69 67 61 74 65 20 77 68 65 72 65 20 74 68 65 0a igate where the.
1150: 09 23 23 20 20 20 20 20 20 20 6d 65 6d 6f 72 79 .## memory
1160: 20 69 73 20 73 70 65 6e 74 20 61 6e 64 20 74 68 is spent and th
1170: 65 6e 20 6c 6f 6f 6b 20 66 6f 72 20 77 61 79 73 en look for ways
1180: 20 6f 66 20 72 65 63 74 69 66 79 69 6e 67 0a 09 of rectifying..
1190: 23 23 20 20 20 20 20 20 20 74 68 65 20 70 72 6f ## the pro
11a0: 62 6c 65 6d 2e 0a 09 23 23 0a 0a 09 23 20 54 68 blem...##...# Th
11b0: 69 73 20 6d 65 74 68 6f 64 20 69 6e 73 70 65 63 is method inspec
11c0: 74 73 20 74 68 65 20 63 68 61 6e 67 65 73 65 74 ts the changeset
11d0: 73 20 66 6f 72 20 69 6e 74 65 72 6e 61 6c 0a 09 s for internal..
11e0: 23 20 64 65 70 65 6e 64 65 6e 63 69 65 73 2e 20 # dependencies.
11f0: 4e 6f 74 68 69 6e 67 20 69 73 20 64 6f 6e 65 20 Nothing is done
1200: 69 66 20 74 68 65 72 65 20 61 72 65 20 6e 6f 0a if there are no.
1210: 09 23 20 73 75 63 68 2e 20 4f 74 68 65 72 77 69 .# such. Otherwi
1220: 73 65 20 74 68 65 20 63 68 61 6e 67 65 73 65 74 se the changeset
1230: 20 69 73 20 73 70 6c 69 74 20 69 6e 74 6f 20 61 is split into a
1240: 20 73 65 74 20 6f 66 0a 09 23 20 66 72 61 67 6d set of..# fragm
1250: 65 6e 74 73 20 77 69 74 68 6f 75 74 20 69 6e 74 ents without int
1260: 65 72 6e 61 6c 20 64 65 70 65 6e 64 65 6e 63 69 ernal dependenci
1270: 65 73 2c 20 74 72 61 6e 73 66 6f 72 6d 69 6e 67 es, transforming
1280: 20 74 68 65 0a 09 23 20 69 6e 74 65 72 6e 61 6c the..# internal
1290: 20 64 65 70 65 6e 64 65 6e 63 69 65 73 20 69 6e dependencies in
12a0: 74 6f 20 65 78 74 65 72 6e 61 6c 20 6f 6e 65 73 to external ones
12b0: 2e 20 54 68 65 20 6e 65 77 20 63 68 61 6e 67 65 . The new change
12c0: 73 65 74 73 0a 09 23 20 61 72 65 20 61 64 64 65 sets..# are adde
12d0: 64 20 74 6f 20 74 68 65 20 6c 69 73 74 20 6f 66 d to the list of
12e0: 20 61 6c 6c 20 63 68 61 6e 67 65 73 65 74 73 2e all changesets.
12f0: 0a 0a 09 23 20 57 65 20 70 65 72 66 6f 72 6d 20 ...# We perform
1300: 61 6c 6c 20 6e 65 63 65 73 73 61 72 79 20 73 70 all necessary sp
1310: 6c 69 74 73 20 69 6e 20 6f 6e 65 20 67 6f 2c 20 lits in one go,
1320: 69 6e 73 74 65 61 64 20 6f 66 20 6f 6e 6c 79 0a instead of only.
1330: 09 23 20 6f 6e 65 2e 20 54 68 65 20 70 72 65 76 .# one. The prev
1340: 69 6f 75 73 20 61 6c 67 6f 72 69 74 68 6d 2c 20 ious algorithm,
1350: 61 64 61 70 74 65 64 20 66 72 6f 6d 20 63 76 73 adapted from cvs
1360: 32 73 76 6e 2c 20 63 6f 6d 70 75 74 65 64 0a 09 2svn, computed..
1370: 23 20 61 20 6c 6f 74 20 6f 66 20 73 74 61 74 65 # a lot of state
1380: 20 77 68 69 63 68 20 77 61 73 20 74 68 72 6f 77 which was throw
1390: 6e 20 61 77 61 79 20 61 6e 64 20 74 68 65 6e 20 n away and then
13a0: 63 6f 6d 70 75 74 65 64 20 61 67 61 69 6e 0a 09 computed again..
13b0: 23 20 66 6f 72 20 65 61 63 68 20 6f 66 20 74 68 # for each of th
13c0: 65 20 66 72 61 67 6d 65 6e 74 73 2e 20 49 74 20 e fragments. It
13d0: 73 68 6f 75 6c 64 20 62 65 20 65 61 73 69 65 72 should be easier
13e0: 20 74 6f 20 75 70 64 61 74 65 20 61 6e 64 0a 09 to update and..
13f0: 23 20 72 65 75 73 65 20 74 68 61 74 20 73 74 61 # reuse that sta
1400: 74 65 2e 0a 0a 09 23 20 54 68 65 20 63 6f 64 65 te....# The code
1410: 20 63 68 65 63 6b 73 20 6f 6e 6c 79 20 73 75 63 checks only suc
1420: 63 65 73 73 6f 72 20 64 65 70 65 6e 64 65 6e 63 cessor dependenc
1430: 69 65 73 2c 20 61 73 20 74 68 69 73 0a 09 23 20 ies, as this..#
1440: 61 75 74 6f 6d 61 74 69 63 61 6c 6c 79 20 63 6f automatically co
1450: 76 65 72 73 20 74 68 65 20 70 72 65 64 65 63 65 vers the predece
1460: 73 73 6f 72 20 64 65 70 65 6e 64 65 6e 63 69 65 ssor dependencie
1470: 73 20 61 73 20 77 65 6c 6c 20 28 41 0a 09 23 20 s as well (A..#
1480: 73 75 63 63 65 73 73 6f 72 20 64 65 70 65 6e 64 successor depend
1490: 65 6e 63 79 20 61 20 2d 3e 20 62 20 69 73 20 61 ency a -> b is a
14a0: 6c 73 6f 20 61 20 70 72 65 64 65 63 65 73 73 6f lso a predecesso
14b0: 72 20 64 65 70 65 6e 64 65 6e 63 79 0a 09 23 20 r dependency..#
14c0: 62 20 2d 3e 20 61 29 2e 0a 0a 09 23 20 41 72 72 b -> a)....# Arr
14d0: 61 79 20 6f 66 20 64 65 70 65 6e 64 65 6e 63 69 ay of dependenci
14e0: 65 73 20 28 70 61 72 65 6e 74 20 2d 3e 20 63 68 es (parent -> ch
14f0: 69 6c 64 29 2e 20 54 68 69 73 20 69 73 20 70 75 ild). This is pu
1500: 6c 6c 65 64 20 66 72 6f 6d 0a 09 23 20 74 68 65 lled from..# the
1510: 20 73 74 61 74 65 2c 20 61 6e 64 20 6c 69 6d 69 state, and limi
1520: 74 65 64 20 74 6f 20 73 75 63 63 65 73 73 6f 72 ted to successor
1530: 73 20 77 69 74 68 69 6e 20 74 68 65 20 63 68 61 s within the cha
1540: 6e 67 65 73 65 74 2e 0a 0a 09 61 72 72 61 79 20 ngeset....array
1550: 73 65 74 20 64 65 70 65 6e 64 65 6e 63 69 65 73 set dependencies
1560: 20 7b 7d 0a 09 24 6d 79 74 79 70 65 6f 62 6a 20 {}..$mytypeobj
1570: 69 6e 74 65 72 6e 61 6c 73 75 63 63 65 73 73 6f internalsuccesso
1580: 72 73 20 64 65 70 65 6e 64 65 6e 63 69 65 73 20 rs dependencies
1590: 24 6d 79 69 74 65 6d 73 0a 09 69 66 20 7b 21 5b $myitems..if {![
15a0: 61 72 72 61 79 20 73 69 7a 65 20 64 65 70 65 6e array size depen
15b0: 64 65 6e 63 69 65 73 5d 7d 20 7b 72 65 74 75 72 dencies]} {retur
15c0: 6e 20 30 7d 20 3b 20 23 20 4e 6f 74 68 69 6e 67 n 0} ; # Nothing
15d0: 20 74 6f 20 62 72 65 61 6b 2e 0a 0a 09 6c 6f 67 to break....log
15e0: 20 77 72 69 74 65 20 35 20 63 73 65 74 73 20 2e write 5 csets .
15f0: 2e 2e 5b 24 73 65 6c 66 20 73 74 72 5d 2e 2e 2e ..[$self str]...
1600: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e ................
1610: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e ................
1620: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e ................
1630: 2e 2e 2e 2e 0a 0a 09 23 20 57 65 20 68 61 76 65 .......# We have
1640: 20 69 6e 74 65 72 6e 61 6c 20 64 65 70 65 6e 64 internal depend
1650: 65 6e 63 69 65 73 20 74 6f 20 62 72 65 61 6b 2e encies to break.
1660: 20 57 65 20 6e 6f 77 20 69 74 65 72 61 74 65 20 We now iterate
1670: 6f 76 65 72 0a 09 23 20 61 6c 6c 20 70 6f 73 69 over..# all posi
1680: 74 69 6f 6e 73 20 69 6e 20 74 68 65 20 6c 69 73 tions in the lis
1690: 74 20 28 77 68 69 63 68 20 69 73 20 63 68 72 6f t (which is chro
16a0: 6e 6f 6c 6f 67 69 63 61 6c 2c 20 61 74 20 6c 65 nological, at le
16b0: 61 73 74 0a 09 23 20 61 73 20 66 61 72 20 61 73 ast..# as far as
16c0: 20 74 68 65 20 74 69 6d 65 73 74 61 6d 70 73 20 the timestamps
16d0: 61 72 65 20 63 6f 72 72 65 63 74 20 61 6e 64 20 are correct and
16e0: 75 6e 69 71 75 65 29 20 61 6e 64 0a 09 23 20 64 unique) and..# d
16f0: 65 74 65 72 6d 69 6e 65 20 74 68 65 20 62 65 73 etermine the bes
1700: 74 20 70 6f 73 69 74 69 6f 6e 20 66 6f 72 20 74 t position for t
1710: 68 65 20 62 72 65 61 6b 2c 20 62 79 20 74 72 79 he break, by try
1720: 69 6e 67 20 74 6f 0a 09 23 20 62 72 65 61 6b 20 ing to..# break
1730: 61 73 20 6d 61 6e 79 20 64 65 70 65 6e 64 65 6e as many dependen
1740: 63 69 65 73 20 61 73 20 70 6f 73 73 69 62 6c 65 cies as possible
1750: 20 69 6e 20 6f 6e 65 20 67 6f 2e 20 57 68 65 6e in one go. When
1760: 20 61 0a 09 23 20 62 72 65 61 6b 20 77 61 73 20 a..# break was
1770: 66 6f 75 6e 64 20 74 68 69 73 20 69 73 20 72 65 found this is re
1780: 64 6f 6e 65 20 66 6f 72 20 74 68 65 20 66 72 61 done for the fra
1790: 67 6d 65 6e 74 73 20 63 6f 6d 69 6e 67 20 61 6e gments coming an
17a0: 64 0a 09 23 20 61 66 74 65 72 2c 20 61 66 74 65 d..# after, afte
17b0: 72 20 75 70 64 69 6e 67 20 74 68 65 20 63 72 6f r upding the cro
17c0: 73 73 69 6e 67 20 69 6e 66 6f 72 6d 61 74 69 6f ssing informatio
17d0: 6e 2e 0a 0a 09 23 20 44 61 74 61 20 73 74 72 75 n....# Data stru
17e0: 63 74 75 72 65 73 3a 0a 09 23 20 4d 61 70 3a 20 ctures:..# Map:
17f0: 20 50 4f 53 20 20 20 72 65 76 69 73 69 6f 6e 20 POS revision
1800: 69 64 20 20 20 20 20 20 2d 3e 20 70 6f 73 69 74 id -> posit
1810: 69 6f 6e 20 69 6e 20 6c 69 73 74 2e 0a 09 23 20 ion in list...#
1820: 20 20 20 20 20 20 43 52 4f 53 53 20 70 6f 73 69 CROSS posi
1830: 74 69 6f 6e 20 69 6e 20 6c 69 73 74 20 2d 3e 20 tion in list ->
1840: 6e 75 6d 62 65 72 20 6f 66 20 64 65 70 65 6e 64 number of depend
1850: 65 6e 63 69 65 73 20 63 72 6f 73 73 69 6e 67 20 encies crossing
1860: 69 74 0a 09 23 20 20 20 20 20 20 20 44 45 50 43 it..# DEPC
1870: 20 20 64 65 70 65 6e 64 65 6e 63 79 20 20 20 20 dependency
1880: 20 20 20 2d 3e 20 70 6f 73 69 74 69 6f 6e 73 20 -> positions
1890: 69 74 20 63 72 6f 73 73 65 73 0a 09 23 20 4c 69 it crosses..# Li
18a0: 73 74 3a 20 52 41 4e 47 45 20 4f 66 20 74 68 65 st: RANGE Of the
18b0: 20 70 6f 73 69 74 69 6f 6e 73 20 69 74 73 65 6c positions itsel
18c0: 66 2e 0a 09 23 20 41 20 64 65 70 65 6e 64 65 6e f...# A dependen
18d0: 63 79 20 69 73 20 61 20 73 69 6e 67 6c 65 2d 65 cy is a single-e
18e0: 6c 65 6d 65 6e 74 20 6d 61 70 20 70 61 72 65 6e lement map paren
18f0: 74 20 2d 3e 20 63 68 69 6c 64 0a 0a 09 49 6e 69 t -> child...Ini
1900: 74 69 61 6c 69 7a 65 42 72 65 61 6b 53 74 61 74 tializeBreakStat
1910: 65 20 24 6d 79 69 74 65 6d 73 0a 0a 09 73 65 74 e $myitems...set
1920: 20 66 72 61 67 6d 65 6e 74 73 20 7b 7d 0a 09 73 fragments {}..s
1930: 65 74 20 6e 65 77 20 20 20 20 20 20 20 5b 6c 69 et new [li
1940: 73 74 20 24 72 61 6e 67 65 5d 0a 09 61 72 72 61 st $range]..arra
1950: 79 20 73 65 74 20 62 72 65 61 6b 73 20 7b 7d 0a y set breaks {}.
1960: 0a 09 23 20 49 6e 73 74 65 61 64 20 6f 66 20 6f ..# Instead of o
1970: 6e 65 20 6c 69 73 74 20 68 6f 6c 64 69 6e 67 20 ne list holding
1980: 62 6f 74 68 20 70 72 6f 63 65 73 73 65 64 20 61 both processed a
1990: 6e 64 20 70 65 6e 64 69 6e 67 0a 09 23 20 66 72 nd pending..# fr
19a0: 61 67 6d 65 6e 74 73 20 77 65 20 75 73 65 20 74 agments we use t
19b0: 77 6f 2c 20 6f 6e 65 20 66 6f 72 20 74 68 65 20 wo, one for the
19c0: 66 72 61 6d 65 6e 74 73 20 74 6f 20 70 72 6f 63 framents to proc
19d0: 65 73 73 2c 20 6f 6e 65 0a 09 23 20 74 6f 20 68 ess, one..# to h
19e0: 6f 6c 64 20 74 68 65 20 6e 65 77 20 66 72 61 67 old the new frag
19f0: 6d 65 6e 74 73 2c 20 61 6e 64 20 74 68 65 20 6c ments, and the l
1a00: 61 74 74 65 72 20 69 73 20 63 6f 70 69 65 64 20 atter is copied
1a10: 74 6f 20 74 68 65 0a 09 23 20 66 6f 72 6d 65 72 to the..# former
1a20: 20 77 68 65 6e 20 74 68 65 79 20 72 75 6e 20 6f when they run o
1a30: 75 74 2e 20 54 68 69 73 20 6b 65 65 70 73 20 74 ut. This keeps t
1a40: 68 65 20 6c 69 73 74 20 6f 66 20 70 65 6e 64 69 he list of pendi
1a50: 6e 67 0a 09 23 20 66 72 61 67 6d 65 6e 74 73 20 ng..# fragments
1a60: 73 68 6f 72 74 20 77 69 74 68 6f 75 74 20 73 61 short without sa
1a70: 63 72 69 66 69 63 69 6e 67 20 73 70 65 65 64 20 crificing speed
1a80: 62 79 20 73 68 69 66 74 69 6e 67 20 73 74 75 66 by shifting stuf
1a90: 66 0a 09 23 20 64 6f 77 6e 2e 20 57 65 20 65 73 f..# down. We es
1aa0: 70 65 63 69 61 6c 6c 79 20 64 72 6f 70 20 74 68 pecially drop th
1ab0: 65 20 6d 65 6d 6f 72 79 20 6f 66 20 66 72 61 67 e memory of frag
1ac0: 6d 65 6e 74 73 20 62 72 6f 6b 65 6e 0a 09 23 20 ments broken..#
1ad0: 64 75 72 69 6e 67 20 70 72 6f 63 65 73 73 69 6e during processin
1ae0: 67 20 61 66 74 65 72 20 61 20 73 68 6f 72 74 20 g after a short
1af0: 74 69 6d 65 2c 20 69 6e 73 74 65 61 64 20 6f 66 time, instead of
1b00: 20 6c 65 74 74 69 6e 67 20 69 74 0a 09 23 20 63 letting it..# c
1b10: 6f 6e 73 75 6d 65 20 6d 65 6d 6f 72 79 2e 0a 0a onsume memory...
1b20: 09 77 68 69 6c 65 20 7b 5b 6c 6c 65 6e 67 74 68 .while {[llength
1b30: 20 24 6e 65 77 5d 7d 20 7b 0a 0a 09 20 20 20 20 $new]} {...
1b40: 73 65 74 20 70 65 6e 64 69 6e 67 20 24 6e 65 77 set pending $new
1b50: 0a 09 20 20 20 20 73 65 74 20 6e 65 77 20 20 20 .. set new
1b60: 20 20 7b 7d 0a 09 20 20 20 20 73 65 74 20 61 74 {}.. set at
1b70: 20 20 20 20 20 20 30 0a 0a 09 20 20 20 20 77 68 0... wh
1b80: 69 6c 65 20 7b 24 61 74 20 3c 20 5b 6c 6c 65 6e ile {$at < [llen
1b90: 67 74 68 20 24 70 65 6e 64 69 6e 67 5d 7d 20 7b gth $pending]} {
1ba0: 0a 09 09 73 65 74 20 63 75 72 72 65 6e 74 20 5b ...set current [
1bb0: 6c 69 6e 64 65 78 20 24 70 65 6e 64 69 6e 67 20 lindex $pending
1bc0: 24 61 74 5d 0a 0a 09 09 6c 6f 67 20 77 72 69 74 $at]....log writ
1bd0: 65 20 36 20 63 73 65 74 73 20 7b 2e 20 2e 20 2e e 6 csets {. . .
1be0: 2e 20 2e 2e 2e 20 2e 2e 2e 2e 2e 20 2e 2e 2e 2e . ... ..... ....
1bf0: 2e 2e 2e 2e 20 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e .... ...........
1c00: 2e 2e 7d 0a 09 09 6c 6f 67 20 77 72 69 74 65 20 ..}...log write
1c10: 36 20 63 73 65 74 73 20 7b 53 63 68 65 64 75 6c 6 csets {Schedul
1c20: 65 64 20 20 20 5b 6a 6f 69 6e 20 5b 50 52 73 20 ed [join [PRs
1c30: 5b 6c 72 61 6e 67 65 20 24 70 65 6e 64 69 6e 67 [lrange $pending
1c40: 20 24 61 74 20 65 6e 64 5d 5d 20 7b 20 7d 5d 7d $at end]] { }]}
1c50: 0a 09 09 6c 6f 67 20 77 72 69 74 65 20 36 20 63 ...log write 6 c
1c60: 73 65 74 73 20 7b 43 6f 6e 73 69 64 65 72 69 6e sets {Considerin
1c70: 67 20 5b 50 52 20 24 63 75 72 72 65 6e 74 5d 20 g [PR $current]
1c80: 5c 5b 24 61 74 2f 5b 6c 6c 65 6e 67 74 68 20 24 \[$at/[llength $
1c90: 70 65 6e 64 69 6e 67 5d 5c 5d 7d 0a 0a 09 09 73 pending]\]}....s
1ca0: 65 74 20 62 65 73 74 20 5b 46 69 6e 64 42 65 73 et best [FindBes
1cb0: 74 42 72 65 61 6b 20 24 63 75 72 72 65 6e 74 5d tBreak $current]
1cc0: 0a 0a 09 09 69 66 20 7b 24 62 65 73 74 20 3c 20 ....if {$best <
1cd0: 30 7d 20 7b 0a 09 09 20 20 20 20 23 20 54 68 65 0} {... # The
1ce0: 20 69 6e 73 70 65 63 74 65 64 20 72 61 6e 67 65 inspected range
1cf0: 20 68 61 73 20 6e 6f 20 69 6e 74 65 72 6e 61 6c has no internal
1d00: 0a 09 09 20 20 20 20 23 20 64 65 70 65 6e 64 65 ... # depende
1d10: 6e 63 69 65 73 2e 20 54 68 69 73 20 69 73 20 61 ncies. This is a
1d20: 20 63 6f 6d 70 6c 65 74 65 20 66 72 61 67 6d 65 complete fragme
1d30: 6e 74 2e 0a 09 09 20 20 20 20 6c 61 70 70 65 6e nt.... lappen
1d40: 64 20 66 72 61 67 6d 65 6e 74 73 20 24 63 75 72 d fragments $cur
1d50: 72 65 6e 74 0a 0a 09 09 20 20 20 20 6c 6f 67 20 rent.... log
1d60: 77 72 69 74 65 20 36 20 63 73 65 74 73 20 22 4e write 6 csets "N
1d70: 6f 20 62 72 65 61 6b 73 2c 20 66 69 6e 61 6c 22 o breaks, final"
1d80: 0a 09 09 7d 20 65 6c 73 65 20 7b 0a 09 09 20 20 ...} else {...
1d90: 20 20 23 20 53 70 6c 69 74 20 74 68 65 20 72 61 # Split the ra
1da0: 6e 67 65 20 61 6e 64 20 73 63 68 65 64 75 6c 65 nge and schedule
1db0: 20 74 68 65 20 72 65 73 75 6c 74 69 6e 67 0a 09 the resulting..
1dc0: 09 20 20 20 20 23 20 66 72 61 67 6d 65 6e 74 73 . # fragments
1dd0: 20 66 6f 72 20 66 75 72 74 68 65 72 20 69 6e 73 for further ins
1de0: 70 65 63 74 69 6f 6e 2e 20 52 65 6d 65 6d 62 65 pection. Remembe
1df0: 72 20 74 68 65 0a 09 09 20 20 20 20 23 20 6e 75 r the... # nu
1e00: 6d 62 65 72 20 6f 66 20 64 65 70 65 6e 64 65 6e mber of dependen
1e10: 63 69 65 73 20 63 75 74 20 62 65 66 6f 72 65 20 cies cut before
1e20: 77 65 20 72 65 6d 6f 76 65 20 74 68 65 6d 0a 09 we remove them..
1e30: 09 20 20 20 20 23 20 66 72 6f 6d 20 63 6f 6e 73 . # from cons
1e40: 69 64 65 72 61 74 69 6f 6e 2c 20 66 6f 72 20 64 ideration, for d
1e50: 6f 63 75 6d 65 6e 74 61 74 69 6f 6e 20 6c 61 74 ocumentation lat
1e60: 65 72 2e 0a 0a 09 09 20 20 20 20 73 65 74 20 62 er..... set b
1e70: 72 65 61 6b 73 28 24 62 65 73 74 29 20 24 63 72 reaks($best) $cr
1e80: 6f 73 73 28 24 62 65 73 74 29 0a 0a 09 09 20 20 oss($best)....
1e90: 20 20 6c 6f 67 20 77 72 69 74 65 20 36 20 63 73 log write 6 cs
1ea0: 65 74 73 20 22 42 65 73 74 20 62 72 65 61 6b 20 ets "Best break
1eb0: 40 20 24 62 65 73 74 2c 20 63 75 74 74 69 6e 67 @ $best, cutting
1ec0: 20 5b 6e 73 70 20 24 63 72 6f 73 73 28 24 62 65 [nsp $cross($be
1ed0: 73 74 29 20 64 65 70 65 6e 64 65 6e 63 79 20 64 st) dependency d
1ee0: 65 70 65 6e 64 65 6e 63 69 65 73 5d 22 0a 0a 09 ependencies]"...
1ef0: 09 20 20 20 20 23 20 4e 6f 74 65 3a 20 54 68 65 . # Note: The
1f00: 20 76 61 6c 75 65 20 6f 66 20 62 65 73 74 20 69 value of best i
1f10: 73 20 61 6e 20 61 62 6f 6c 75 74 65 20 6c 6f 63 s an abolute loc
1f20: 61 74 69 6f 6e 0a 09 09 20 20 20 20 23 20 69 6e ation... # in
1f30: 20 6d 79 69 74 65 6d 73 2e 20 55 73 65 20 74 68 myitems. Use th
1f40: 65 20 73 74 61 72 74 20 6f 66 20 63 75 72 72 65 e start of curre
1f50: 6e 74 20 74 6f 20 6d 61 6b 65 20 69 74 0a 09 09 nt to make it...
1f60: 20 20 20 20 23 20 61 6e 20 69 6e 64 65 78 20 61 # an index a
1f70: 62 73 6f 6c 75 74 65 20 74 6f 20 63 75 72 72 65 bsolute to curre
1f80: 6e 74 2e 0a 0a 09 09 20 20 20 20 73 65 74 20 62 nt..... set b
1f90: 72 65 6c 20 5b 65 78 70 72 20 7b 24 62 65 73 74 rel [expr {$best
1fa0: 20 2d 20 5b 6c 69 6e 64 65 78 20 24 63 75 72 72 - [lindex $curr
1fb0: 65 6e 74 20 30 5d 7d 5d 0a 09 09 20 20 20 20 73 ent 0]}]... s
1fc0: 65 74 20 62 6e 65 78 74 20 24 62 72 65 6c 20 3b et bnext $brel ;
1fd0: 20 69 6e 63 72 20 62 6e 65 78 74 0a 09 09 20 20 incr bnext...
1fe0: 20 20 73 65 74 20 66 72 61 67 62 65 66 6f 72 65 set fragbefore
1ff0: 20 5b 6c 72 61 6e 67 65 20 24 63 75 72 72 65 6e [lrange $curren
2000: 74 20 30 20 24 62 72 65 6c 5d 0a 09 09 20 20 20 t 0 $brel]...
2010: 20 73 65 74 20 66 72 61 67 61 66 74 65 72 20 20 set fragafter
2020: 5b 6c 72 61 6e 67 65 20 24 63 75 72 72 65 6e 74 [lrange $current
2030: 20 24 62 6e 65 78 74 20 65 6e 64 5d 0a 0a 09 09 $bnext end]....
2040: 20 20 20 20 6c 6f 67 20 77 72 69 74 65 20 36 20 log write 6
2050: 63 73 65 74 73 20 22 4e 65 77 20 70 69 65 63 65 csets "New piece
2060: 73 20 20 5b 50 52 20 24 66 72 61 67 62 65 66 6f s [PR $fragbefo
2070: 72 65 5d 20 5b 50 52 20 24 66 72 61 67 61 66 74 re] [PR $fragaft
2080: 65 72 5d 22 0a 0a 09 09 20 20 20 20 69 6e 74 65 er]".... inte
2090: 67 72 69 74 79 20 61 73 73 65 72 74 20 7b 5b 6c grity assert {[l
20a0: 6c 65 6e 67 74 68 20 24 66 72 61 67 62 65 66 6f length $fragbefo
20b0: 72 65 5d 7d 20 7b 46 6f 75 6e 64 20 7a 65 72 6f re]} {Found zero
20c0: 2d 6c 65 6e 67 74 68 20 66 72 61 67 6d 65 6e 74 -length fragment
20d0: 20 61 74 20 74 68 65 20 62 65 67 69 6e 6e 69 6e at the beginnin
20e0: 67 7d 0a 09 09 20 20 20 20 69 6e 74 65 67 72 69 g}... integri
20f0: 74 79 20 61 73 73 65 72 74 20 7b 5b 6c 6c 65 6e ty assert {[llen
2100: 67 74 68 20 24 66 72 61 67 61 66 74 65 72 5d 7d gth $fragafter]}
2110: 20 20 7b 46 6f 75 6e 64 20 7a 65 72 6f 2d 6c 65 {Found zero-le
2120: 6e 67 74 68 20 66 72 61 67 6d 65 6e 74 20 61 74 ngth fragment at
2130: 20 74 68 65 20 65 6e 64 7d 0a 0a 09 09 20 20 20 the end}....
2140: 20 6c 61 70 70 65 6e 64 20 6e 65 77 20 24 66 72 lappend new $fr
2150: 61 67 62 65 66 6f 72 65 20 24 66 72 61 67 61 66 agbefore $fragaf
2160: 74 65 72 0a 09 09 20 20 20 20 43 75 74 41 74 20 ter... CutAt
2170: 24 62 65 73 74 0a 09 09 7d 0a 0a 09 09 69 6e 63 $best...}....inc
2180: 72 20 61 74 0a 09 20 20 20 20 7d 0a 09 7d 0a 0a r at.. }..}..
2190: 09 6c 6f 67 20 77 72 69 74 65 20 36 20 63 73 65 .log write 6 cse
21a0: 74 73 20 22 2e 20 2e 20 2e 2e 20 2e 2e 2e 20 2e ts ". . .. ... .
21b0: 2e 2e 2e 2e 20 2e 2e 2e 2e 2e 2e 2e 2e 20 2e 2e .... ........ ..
21c0: 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 2e 22 0a 0a 09 23 ..........."...#
21d0: 20 28 2a 29 20 57 65 20 63 6c 65 61 72 20 6f 75 (*) We clear ou
21e0: 74 20 74 68 65 20 61 73 73 6f 63 69 61 74 65 64 t the associated
21f0: 20 70 61 72 74 20 6f 66 20 74 68 65 20 6d 79 69 part of the myi
2200: 74 65 6d 6d 61 70 0a 09 23 20 69 6e 2d 6d 65 6d temmap..# in-mem
2210: 6f 72 79 20 69 6e 64 65 78 20 69 6e 20 70 72 65 ory index in pre
2220: 70 61 72 61 74 69 6f 6e 20 66 6f 72 20 6e 65 77 paration for new
2230: 20 64 61 74 61 2e 20 41 20 73 69 6d 70 6c 65 20 data. A simple
2240: 75 6e 73 65 74 0a 09 23 20 69 73 20 65 6e 6f 75 unset..# is enou
2250: 67 68 2c 20 77 65 20 68 61 76 65 20 6e 6f 20 73 gh, we have no s
2260: 79 6d 62 6f 6c 20 63 68 61 6e 67 65 73 65 74 73 ymbol changesets
2270: 20 61 74 20 74 68 69 73 20 74 69 6d 65 2c 20 61 at this time, a
2280: 6e 64 0a 09 23 20 74 68 75 73 20 6e 65 76 65 72 nd..# thus never
2290: 20 6d 6f 72 65 20 74 68 61 6e 20 6f 6e 65 20 72 more than one r
22a0: 65 66 65 72 65 6e 63 65 20 69 6e 20 74 68 65 20 eference in the
22b0: 6c 69 73 74 2e 0a 0a 09 66 6f 72 65 61 63 68 20 list....foreach
22c0: 69 69 64 20 24 6d 79 69 74 65 6d 73 20 7b 0a 09 iid $myitems {..
22d0: 20 20 20 20 73 65 74 20 6b 65 79 20 5b 6c 69 73 set key [lis
22e0: 74 20 24 6d 79 74 79 70 65 20 24 69 69 64 5d 0a t $mytype $iid].
22f0: 09 20 20 20 20 75 6e 73 65 74 20 6d 79 69 74 65 . unset myite
2300: 6d 6d 61 70 28 24 6b 65 79 29 0a 09 20 20 20 20 mmap($key)..
2310: 6c 6f 67 20 77 72 69 74 65 20 38 20 63 73 65 74 log write 8 cset
2320: 73 20 7b 4d 41 50 2d 20 69 74 65 6d 20 3c 24 6b s {MAP- item <$k
2330: 65 79 3e 20 24 73 65 6c 66 20 3d 20 5b 24 73 65 ey> $self = [$se
2340: 6c 66 20 73 74 72 5d 7d 0a 09 7d 0a 0a 09 23 20 lf str]}..}...#
2350: 43 72 65 61 74 65 20 63 68 61 6e 67 65 73 65 74 Create changeset
2360: 73 20 66 6f 72 20 74 68 65 20 66 72 61 67 6d 65 s for the fragme
2370: 6e 74 73 2c 20 72 65 75 73 69 6e 67 20 74 68 65 nts, reusing the
2380: 20 63 75 72 72 65 6e 74 20 6f 6e 65 0a 09 23 20 current one..#
2390: 66 6f 72 20 74 68 65 20 66 69 72 73 74 20 66 72 for the first fr
23a0: 61 67 6d 65 6e 74 2e 20 57 65 20 73 6f 72 74 20 agment. We sort
23b0: 74 68 65 6d 20 69 6e 20 6f 72 64 65 72 20 74 6f them in order to
23c0: 20 61 6c 6c 6f 77 0a 09 23 20 63 68 65 63 6b 69 allow..# checki
23d0: 6e 67 20 66 6f 72 20 67 61 70 73 20 61 6e 64 20 ng for gaps and
23e0: 6e 69 63 65 20 6d 65 73 73 61 67 65 73 2e 0a 0a nice messages...
23f0: 09 73 65 74 20 66 72 61 67 6d 65 6e 74 73 20 5b .set fragments [
2400: 6c 73 6f 72 74 20 2d 69 6e 64 65 78 20 30 20 2d lsort -index 0 -
2410: 69 6e 74 65 67 65 72 20 24 66 72 61 67 6d 65 6e integer $fragmen
2420: 74 73 5d 0a 0a 09 23 70 75 74 73 20 5c 74 2e 5b ts]...#puts \t.[
2430: 6a 6f 69 6e 20 5b 50 52 73 20 24 66 72 61 67 6d join [PRs $fragm
2440: 65 6e 74 73 5d 20 2e 5c 6e 5c 74 2e 5d 2e 0a 0a ents] .\n\t.]...
2450: 09 42 6f 72 64 65 72 20 5b 6c 69 6e 64 65 78 20 .Border [lindex
2460: 24 66 72 61 67 6d 65 6e 74 73 20 30 5d 20 66 69 $fragments 0] fi
2470: 72 73 74 73 20 66 69 72 73 74 65 0a 0a 09 69 6e rsts firste...in
2480: 74 65 67 72 69 74 79 20 61 73 73 65 72 74 20 7b tegrity assert {
2490: 24 66 69 72 73 74 73 20 3d 3d 20 30 7d 20 7b 42 $firsts == 0} {B
24a0: 61 64 20 66 72 61 67 6d 65 6e 74 20 73 74 61 72 ad fragment star
24b0: 74 20 40 20 24 66 69 72 73 74 73 2c 20 67 61 70 t @ $firsts, gap
24c0: 2c 20 6f 72 20 62 65 66 6f 72 65 20 62 65 67 69 , or before begi
24d0: 6e 6e 69 6e 67 20 6f 66 20 74 68 65 20 72 61 6e nning of the ran
24e0: 67 65 7d 0a 0a 09 73 65 74 20 6c 61 73 74 65 20 ge}...set laste
24f0: 24 66 69 72 73 74 65 0a 09 66 6f 72 65 61 63 68 $firste..foreach
2500: 20 66 72 61 67 6d 65 6e 74 20 5b 6c 72 61 6e 67 fragment [lrang
2510: 65 20 24 66 72 61 67 6d 65 6e 74 73 20 31 20 65 e $fragments 1 e
2520: 6e 64 5d 20 7b 0a 09 20 20 20 20 42 6f 72 64 65 nd] {.. Borde
2530: 72 20 24 66 72 61 67 6d 65 6e 74 20 73 20 65 0a r $fragment s e.
2540: 09 20 20 20 20 69 6e 74 65 67 72 69 74 79 20 61 . integrity a
2550: 73 73 65 72 74 20 7b 24 6c 61 73 74 65 20 3d 3d ssert {$laste ==
2560: 20 28 24 73 20 2d 20 31 29 7d 20 7b 42 61 64 20 ($s - 1)} {Bad
2570: 66 72 61 67 6d 65 6e 74 20 62 6f 72 64 65 72 20 fragment border
2580: 3c 24 6c 61 73 74 65 20 7c 20 24 73 3e 2c 20 67 <$laste | $s>, g
2590: 61 70 20 6f 72 20 6f 76 65 72 6c 61 70 7d 0a 0a ap or overlap}..
25a0: 09 20 20 20 20 73 65 74 20 6e 65 77 20 5b 24 74 . set new [$t
25b0: 79 70 65 20 25 41 55 54 4f 25 20 24 6d 79 70 72 ype %AUTO% $mypr
25c0: 6f 6a 65 63 74 20 24 6d 79 74 79 70 65 20 24 6d oject $mytype $m
25d0: 79 73 72 63 69 64 20 5b 6c 72 61 6e 67 65 20 24 ysrcid [lrange $
25e0: 6d 79 69 74 65 6d 73 20 24 73 20 24 65 5d 5d 0a myitems $s $e]].
25f0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 6c 6f 67 . log
2600: 20 77 72 69 74 65 20 34 20 63 73 65 74 73 20 22 write 4 csets "
2610: 42 72 65 61 6b 69 6e 67 20 5b 24 73 65 6c 66 20 Breaking [$self
2620: 73 74 72 20 5d 20 40 20 24 6c 61 73 74 65 2c 20 str ] @ $laste,
2630: 6e 65 77 20 5b 24 6e 65 77 20 73 74 72 5d 2c 20 new [$new str],
2640: 63 75 74 74 69 6e 67 20 24 62 72 65 61 6b 73 28 cutting $breaks(
2650: 24 6c 61 73 74 65 29 22 0a 0a 09 20 20 20 20 73 $laste)"... s
2660: 65 74 20 6c 61 73 74 65 20 24 65 0a 09 7d 0a 0a et laste $e..}..
2670: 09 69 6e 74 65 67 72 69 74 79 20 61 73 73 65 72 .integrity asser
2680: 74 20 7b 0a 09 20 20 20 20 24 6c 61 73 74 65 20 t {.. $laste
2690: 3d 3d 20 28 5b 6c 6c 65 6e 67 74 68 20 24 6d 79 == ([llength $my
26a0: 69 74 65 6d 73 5d 2d 31 29 0a 09 7d 20 7b 42 61 items]-1)..} {Ba
26b0: 64 20 66 72 61 67 6d 65 6e 74 20 65 6e 64 20 40 d fragment end @
26c0: 20 24 6c 61 73 74 65 2c 20 67 61 70 2c 20 6f 72 $laste, gap, or
26d0: 20 62 65 79 6f 6e 64 20 65 6e 64 20 6f 66 20 74 beyond end of t
26e0: 68 65 20 72 61 6e 67 65 7d 0a 0a 09 23 20 50 75 he range}...# Pu
26f0: 74 20 74 68 65 20 66 69 72 73 74 20 66 72 61 67 t the first frag
2700: 6d 65 6e 74 20 69 6e 74 6f 20 74 68 65 20 63 75 ment into the cu
2710: 72 72 65 6e 74 20 63 68 61 6e 67 65 73 65 74 2c rrent changeset,
2720: 20 61 6e 64 0a 09 23 20 75 70 64 61 74 65 20 74 and..# update t
2730: 68 65 20 69 6e 2d 6d 65 6d 6f 72 79 20 69 6e 64 he in-memory ind
2740: 65 78 2e 20 57 65 20 63 61 6e 20 73 69 6d 70 6c ex. We can simpl
2750: 79 20 28 72 65 29 61 64 64 20 74 68 65 20 69 74 y (re)add the it
2760: 65 6d 73 0a 09 23 20 62 65 63 61 75 73 65 20 77 ems..# because w
2770: 65 20 63 6c 65 61 72 65 64 20 74 68 65 20 70 72 e cleared the pr
2780: 65 76 69 6f 75 73 6c 79 20 65 78 69 73 74 69 6e eviously existin
2790: 67 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 2c 20 73 g information, s
27a0: 65 65 0a 09 23 20 28 2a 29 20 61 62 6f 76 65 2e ee..# (*) above.
27b0: 20 50 65 72 73 69 73 74 65 6e 63 65 20 64 6f 65 Persistence doe
27c0: 73 20 6e 6f 74 20 6d 61 74 74 65 72 20 68 65 72 s not matter her
27d0: 65 2c 20 6e 6f 6e 65 20 6f 66 20 74 68 65 0a 09 e, none of the..
27e0: 23 20 63 68 61 6e 67 65 73 65 74 73 20 68 61 73 # changesets has
27f0: 20 62 65 65 6e 20 73 61 76 65 64 20 74 6f 20 74 been saved to t
2800: 68 65 20 70 65 72 73 69 73 74 65 6e 74 20 73 74 he persistent st
2810: 61 74 65 20 79 65 74 2e 0a 0a 09 73 65 74 20 6d ate yet....set m
2820: 79 69 74 65 6d 73 20 20 5b 6c 72 61 6e 67 65 20 yitems [lrange
2830: 24 6d 79 69 74 65 6d 73 20 20 30 20 24 66 69 72 $myitems 0 $fir
2840: 73 74 65 5d 0a 09 73 65 74 20 6d 79 74 69 74 65 ste]..set mytite
2850: 6d 73 20 5b 6c 72 61 6e 67 65 20 24 6d 79 74 69 ms [lrange $myti
2860: 74 65 6d 73 20 30 20 24 66 69 72 73 74 65 5d 0a tems 0 $firste].
2870: 09 66 6f 72 65 61 63 68 20 69 69 64 20 24 6d 79 .foreach iid $my
2880: 69 74 65 6d 73 20 7b 0a 09 20 20 20 20 73 65 74 items {.. set
2890: 20 6b 65 79 20 5b 6c 69 73 74 20 24 6d 79 74 79 key [list $myty
28a0: 70 65 20 24 69 69 64 5d 0a 09 20 20 20 20 73 65 pe $iid].. se
28b0: 74 20 6d 79 69 74 65 6d 6d 61 70 28 24 6b 65 79 t myitemmap($key
28c0: 29 20 24 73 65 6c 66 0a 09 20 20 20 20 6c 6f 67 ) $self.. log
28d0: 20 77 72 69 74 65 20 38 20 63 73 65 74 73 20 7b write 8 csets {
28e0: 4d 41 50 2b 20 69 74 65 6d 20 3c 24 6b 65 79 3e MAP+ item <$key>
28f0: 20 24 73 65 6c 66 20 3d 20 5b 24 73 65 6c 66 20 $self = [$self
2900: 73 74 72 5d 7d 0a 09 7d 0a 0a 09 72 65 74 75 72 str]}..}...retur
2910: 6e 20 31 0a 20 20 20 20 7d 0a 0a 20 20 20 20 6d n 1. }.. m
2920: 65 74 68 6f 64 20 70 65 72 73 69 73 74 20 7b 7d ethod persist {}
2930: 20 7b 0a 09 73 65 74 20 74 69 64 20 24 6d 79 63 {..set tid $myc
2940: 73 74 79 70 65 28 24 6d 79 74 79 70 65 29 0a 09 stype($mytype)..
2950: 73 65 74 20 70 69 64 20 5b 24 6d 79 70 72 6f 6a set pid [$myproj
2960: 65 63 74 20 69 64 5d 0a 09 73 65 74 20 70 6f 73 ect id]..set pos
2970: 20 30 0a 0a 09 73 74 61 74 65 20 74 72 61 6e 73 0...state trans
2980: 61 63 74 69 6f 6e 20 7b 0a 09 20 20 20 20 73 74 action {.. st
2990: 61 74 65 20 72 75 6e 20 7b 0a 09 09 49 4e 53 45 ate run {...INSE
29a0: 52 54 20 49 4e 54 4f 20 63 68 61 6e 67 65 73 65 RT INTO changese
29b0: 74 20 28 63 69 64 2c 20 20 20 70 69 64 2c 20 20 t (cid, pid,
29c0: 74 79 70 65 2c 20 73 72 63 29 0a 09 09 56 41 4c type, src)...VAL
29d0: 55 45 53 20 20 20 20 20 20 20 20 20 20 20 20 20 UES
29e0: 20 20 20 28 24 6d 79 69 64 2c 20 24 70 69 64 2c ($myid, $pid,
29f0: 20 24 74 69 64 2c 20 24 6d 79 73 72 63 69 64 29 $tid, $mysrcid)
2a00: 3b 0a 09 20 20 20 20 7d 0a 0a 09 20 20 20 20 66 ;.. }... f
2a10: 6f 72 65 61 63 68 20 69 69 64 20 24 6d 79 69 74 oreach iid $myit
2a20: 65 6d 73 20 7b 0a 09 09 73 74 61 74 65 20 72 75 ems {...state ru
2a30: 6e 20 7b 0a 09 09 20 20 20 20 49 4e 53 45 52 54 n {... INSERT
2a40: 20 49 4e 54 4f 20 63 73 69 74 65 6d 20 28 63 69 INTO csitem (ci
2a50: 64 2c 20 20 20 70 6f 73 2c 20 20 69 69 64 29 0a d, pos, iid).
2a60: 09 09 20 20 20 20 56 41 4c 55 45 53 20 20 20 20 .. VALUES
2a70: 20 20 20 20 20 20 20 20 20 28 24 6d 79 69 64 2c ($myid,
2a80: 20 24 70 6f 73 2c 20 24 69 69 64 29 3b 0a 09 09 $pos, $iid);...
2a90: 7d 0a 09 09 69 6e 63 72 20 70 6f 73 0a 09 20 20 }...incr pos..
2aa0: 20 20 7d 0a 09 7d 0a 09 72 65 74 75 72 6e 0a 20 }..}..return.
2ab0: 20 20 20 7d 0a 0a 20 20 20 20 6d 65 74 68 6f 64 }.. method
2ac0: 20 74 69 6d 65 72 61 6e 67 65 20 7b 7d 20 7b 20 timerange {} {
2ad0: 72 65 74 75 72 6e 20 5b 24 6d 79 74 79 70 65 6f return [$mytypeo
2ae0: 62 6a 20 74 69 6d 65 72 61 6e 67 65 20 24 6d 79 bj timerange $my
2af0: 69 74 65 6d 73 5d 20 7d 0a 0a 20 20 20 20 6d 65 items] }.. me
2b00: 74 68 6f 64 20 6c 69 6d 69 74 73 20 7b 7d 20 7b thod limits {} {
2b10: 0a 09 73 74 72 75 63 74 3a 3a 6c 69 73 74 20 61 ..struct::list a
2b20: 73 73 69 67 6e 20 5b 24 6d 79 74 79 70 65 6f 62 ssign [$mytypeob
2b30: 6a 20 6c 69 6d 69 74 73 20 24 6d 79 69 74 65 6d j limits $myitem
2b40: 73 5d 20 6d 61 78 70 20 6d 69 6e 73 0a 09 72 65 s] maxp mins..re
2b50: 74 75 72 6e 20 5b 6c 69 73 74 20 5b 54 61 67 49 turn [list [TagI
2b60: 74 65 6d 44 69 63 74 20 24 6d 61 78 70 20 24 6d temDict $maxp $m
2b70: 79 74 79 70 65 5d 20 5b 54 61 67 49 74 65 6d 44 ytype] [TagItemD
2b80: 69 63 74 20 24 6d 69 6e 73 20 24 6d 79 74 79 70 ict $mins $mytyp
2b90: 65 5d 5d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 6d e]]. }.. m
2ba0: 65 74 68 6f 64 20 64 72 6f 70 20 7b 7d 20 7b 0a ethod drop {} {.
2bb0: 09 6c 6f 67 20 77 72 69 74 65 20 38 20 63 73 65 .log write 8 cse
2bc0: 74 73 20 7b 44 72 6f 70 70 69 6e 67 20 24 73 65 ts {Dropping $se
2bd0: 6c 66 20 3d 20 5b 24 73 65 6c 66 20 73 74 72 5d lf = [$self str]
2be0: 7d 0a 0a 09 73 74 61 74 65 20 74 72 61 6e 73 61 }...state transa
2bf0: 63 74 69 6f 6e 20 7b 0a 09 20 20 20 20 73 74 61 ction {.. sta
2c00: 74 65 20 72 75 6e 20 7b 0a 09 09 44 45 4c 45 54 te run {...DELET
2c10: 45 20 46 52 4f 4d 20 63 68 61 6e 67 65 73 65 74 E FROM changeset
2c20: 20 20 20 57 48 45 52 45 20 63 69 64 20 3d 20 24 WHERE cid = $
2c30: 6d 79 69 64 3b 0a 09 09 44 45 4c 45 54 45 20 46 myid;...DELETE F
2c40: 52 4f 4d 20 63 73 69 74 65 6d 20 20 20 20 20 20 ROM csitem
2c50: 57 48 45 52 45 20 63 69 64 20 3d 20 24 6d 79 69 WHERE cid = $myi
2c60: 64 3b 0a 09 09 44 45 4c 45 54 45 20 46 52 4f 4d d;...DELETE FROM
2c70: 20 63 73 73 75 63 63 65 73 73 6f 72 20 57 48 45 cssuccessor WHE
2c80: 52 45 20 63 69 64 20 3d 20 24 6d 79 69 64 3b 0a RE cid = $myid;.
2c90: 09 20 20 20 20 7d 0a 09 7d 0a 09 66 6f 72 65 61 . }..}..forea
2ca0: 63 68 20 69 69 64 20 24 6d 79 69 74 65 6d 73 20 ch iid $myitems
2cb0: 7b 0a 09 20 20 20 20 73 65 74 20 6b 65 79 20 5b {.. set key [
2cc0: 6c 69 73 74 20 24 6d 79 74 79 70 65 20 24 69 69 list $mytype $ii
2cd0: 64 5d 0a 09 20 20 20 20 75 6e 73 65 74 20 6d 79 d].. unset my
2ce0: 69 74 65 6d 6d 61 70 28 24 6b 65 79 29 0a 09 20 itemmap($key)..
2cf0: 20 20 20 6c 6f 67 20 77 72 69 74 65 20 38 20 63 log write 8 c
2d00: 73 65 74 73 20 7b 4d 41 50 2d 20 69 74 65 6d 20 sets {MAP- item
2d10: 3c 24 6b 65 79 3e 20 24 73 65 6c 66 20 3d 20 5b <$key> $self = [
2d20: 24 73 65 6c 66 20 73 74 72 5d 7d 0a 09 7d 0a 09 $self str]}..}..
2d30: 73 65 74 20 70 6f 73 20 20 20 20 20 20 20 20 20 set pos
2d40: 20 5b 6c 73 65 61 72 63 68 20 2d 65 78 61 63 74 [lsearch -exact
2d50: 20 24 6d 79 63 68 61 6e 67 65 73 65 74 73 20 24 $mychangesets $
2d60: 73 65 6c 66 5d 0a 09 73 65 74 20 6d 79 63 68 61 self]..set mycha
2d70: 6e 67 65 73 65 74 73 20 5b 6c 72 65 70 6c 61 63 ngesets [lreplac
2d80: 65 20 24 6d 79 63 68 61 6e 67 65 73 65 74 73 20 e $mychangesets
2d90: 24 70 6f 73 20 24 70 6f 73 5d 0a 09 73 65 74 20 $pos $pos]..set
2da0: 70 6f 73 20 20 20 20 20 20 20 20 20 20 20 20 20 pos
2db0: 20 20 20 20 20 20 20 5b 6c 73 65 61 72 63 68 20 [lsearch
2dc0: 2d 65 78 61 63 74 20 24 6d 79 74 63 68 61 6e 67 -exact $mytchang
2dd0: 65 73 65 74 73 28 24 6d 79 74 79 70 65 29 20 24 esets($mytype) $
2de0: 73 65 6c 66 5d 0a 09 73 65 74 20 6d 79 74 63 68 self]..set mytch
2df0: 61 6e 67 65 73 65 74 73 28 24 6d 79 74 79 70 65 angesets($mytype
2e00: 29 20 5b 6c 72 65 70 6c 61 63 65 20 24 6d 79 74 ) [lreplace $myt
2e10: 63 68 61 6e 67 65 73 65 74 73 28 24 6d 79 74 79 changesets($myty
2e20: 70 65 29 20 24 70 6f 73 20 24 70 6f 73 5d 0a 0a pe) $pos $pos]..
2e30: 09 23 20 52 65 74 75 72 6e 20 74 68 65 20 6c 69 .# Return the li
2e40: 73 74 20 6f 66 20 70 72 65 64 65 63 65 73 73 6f st of predecesso
2e50: 72 73 20 73 6f 20 74 68 61 74 20 74 68 65 79 20 rs so that they
2e60: 63 61 6e 20 62 65 20 61 64 6a 75 73 74 65 64 2e can be adjusted.
2e70: 0a 09 72 65 74 75 72 6e 20 5b 73 74 72 75 63 74 ..return [struct
2e80: 3a 3a 6c 69 73 74 20 6d 61 70 20 5b 73 74 61 74 ::list map [stat
2e90: 65 20 72 75 6e 20 7b 0a 09 20 20 20 20 53 45 4c e run {.. SEL
2ea0: 45 43 54 20 63 69 64 0a 09 20 20 20 20 46 52 4f ECT cid.. FRO
2eb0: 4d 20 20 20 63 73 73 75 63 63 65 73 73 6f 72 0a M cssuccessor.
2ec0: 09 20 20 20 20 57 48 45 52 45 20 20 6e 69 64 20 . WHERE nid
2ed0: 3d 20 24 6d 79 69 64 0a 09 7d 5d 20 5b 6d 79 74 = $myid..}] [myt
2ee0: 79 70 65 6d 65 74 68 6f 64 20 6f 66 5d 5d 0a 20 ypemethod of]].
2ef0: 20 20 20 7d 0a 0a 20 20 20 20 6d 65 74 68 6f 64 }.. method
2f00: 20 72 65 70 6f 72 74 6c 6f 6f 70 20 7b 7b 6b 69 reportloop {{ki
2f10: 6c 6c 20 31 7d 7d 20 7b 0a 09 23 20 57 65 20 70 ll 1}} {..# We p
2f20: 72 69 6e 74 20 74 68 65 20 69 74 65 6d 73 20 77 rint the items w
2f30: 68 69 63 68 20 61 72 65 20 70 72 6f 64 75 63 69 hich are produci
2f40: 6e 67 20 74 68 65 20 6c 6f 6f 70 2c 20 61 6e 64 ng the loop, and
2f50: 20 68 6f 77 2e 0a 0a 09 73 65 74 20 68 64 72 20 how....set hdr
2f60: 22 53 65 6c 66 2d 72 65 66 65 72 65 6e 74 69 61 "Self-referentia
2f70: 6c 20 63 68 61 6e 67 65 73 65 74 20 5b 24 73 65 l changeset [$se
2f80: 6c 66 20 73 74 72 5d 20 5f 5f 5f 5f 5f 5f 5f 5f lf str] ________
2f90: 5f 5f 5f 5f 5f 5f 5f 5f 5f 5f 22 0a 09 73 65 74 __________"..set
2fa0: 20 66 74 72 20 5b 72 65 67 73 75 62 20 2d 61 6c ftr [regsub -al
2fb0: 6c 20 7b 5b 5e 20 09 5d 7d 20 24 68 64 72 20 7b l {[^ .]} $hdr {
2fc0: 5f 7d 5d 0a 0a 09 6c 6f 67 20 77 72 69 74 65 20 _}]...log write
2fd0: 30 20 63 73 65 74 73 20 24 68 64 72 0a 09 66 6f 0 csets $hdr..fo
2fe0: 72 65 61 63 68 20 7b 69 74 65 6d 20 6e 65 78 74 reach {item next
2ff0: 69 74 65 6d 7d 20 5b 24 6d 79 74 79 70 65 6f 62 item} [$mytypeob
3000: 6a 20 6c 6f 6f 70 73 20 24 6d 79 69 74 65 6d 73 j loops $myitems
3010: 5d 20 7b 0a 09 20 20 20 20 23 20 43 72 65 61 74 ] {.. # Creat
3020: 65 20 74 61 67 67 65 64 20 69 74 65 6d 73 20 66 e tagged items f
3030: 72 6f 6d 20 74 68 65 20 69 64 20 61 6e 64 20 6f rom the id and o
3040: 75 72 20 74 79 70 65 2e 0a 09 20 20 20 20 73 65 ur type... se
3050: 74 20 69 74 65 6d 20 20 20 20 20 5b 6c 69 73 74 t item [list
3060: 20 24 6d 79 74 79 70 65 20 20 24 69 74 65 6d 5d $mytype $item]
3070: 0a 09 20 20 20 20 73 65 74 20 6e 65 78 74 69 74 .. set nextit
3080: 65 6d 20 5b 6c 69 73 74 20 24 6d 79 74 79 70 65 em [list $mytype
3090: 20 24 6e 65 78 74 69 74 65 6d 5d 0a 09 20 20 20 $nextitem]..
30a0: 20 23 20 50 72 69 6e 74 61 62 6c 65 20 6c 61 62 # Printable lab
30b0: 65 6c 73 2e 0a 09 20 20 20 20 73 65 74 20 69 20 els... set i
30c0: 20 22 3c 5b 24 74 79 70 65 20 69 74 65 6d 73 74 "<[$type itemst
30d0: 72 20 24 69 74 65 6d 5d 3e 22 0a 09 20 20 20 20 r $item]>"..
30e0: 73 65 74 20 6e 20 20 22 3c 5b 24 74 79 70 65 20 set n "<[$type
30f0: 69 74 65 6d 73 74 72 20 24 6e 65 78 74 69 74 65 itemstr $nextite
3100: 6d 5d 3e 22 0a 09 20 20 20 20 73 65 74 20 6e 63 m]>".. set nc
3110: 73 20 24 6d 79 69 74 65 6d 6d 61 70 28 24 6e 65 s $myitemmap($ne
3120: 78 74 69 74 65 6d 29 0a 09 20 20 20 20 23 20 50 xtitem).. # P
3130: 72 69 6e 74 0a 09 20 20 20 20 6c 6f 67 20 77 72 rint.. log wr
3140: 69 74 65 20 30 20 63 73 65 74 73 20 7b 2a 20 24 ite 0 csets {* $
3150: 69 20 2d 2d 3e 20 24 6e 20 2d 2d 3e 20 63 73 20 i --> $n --> cs
3160: 5b 24 6e 63 73 20 73 74 72 5d 7d 0a 09 7d 0a 09 [$ncs str]}..}..
3170: 6c 6f 67 20 77 72 69 74 65 20 30 20 63 73 65 74 log write 0 cset
3180: 73 20 24 66 74 72 0a 0a 09 69 66 20 7b 21 24 6b s $ftr...if {!$k
3190: 69 6c 6c 7d 20 72 65 74 75 72 6e 0a 09 74 72 6f ill} return..tro
31a0: 75 62 6c 65 20 69 6e 74 65 72 6e 61 6c 20 22 5b uble internal "[
31b0: 24 73 65 6c 66 20 73 74 72 5d 20 64 65 70 65 6e $self str] depen
31c0: 64 73 20 6f 6e 20 69 74 73 65 6c 66 22 0a 09 72 ds on itself"..r
31d0: 65 74 75 72 6e 0a 20 20 20 20 7d 0a 0a 20 20 20 eturn. }..
31e0: 20 6d 65 74 68 6f 64 20 70 75 73 68 74 6f 20 7b method pushto {
31f0: 73 76 20 72 65 70 6f 73 69 74 6f 72 79 20 64 61 sv repository da
3200: 74 65 7d 20 7b 0a 09 75 70 76 61 72 20 31 20 24 te} {..upvar 1 $
3210: 73 76 20 73 74 61 74 65 0a 0a 09 23 20 47 65 6e sv state...# Gen
3220: 65 72 61 74 65 20 61 6e 64 20 69 6d 70 6f 72 74 erate and import
3230: 20 74 68 65 20 6d 61 6e 69 66 65 73 74 20 66 6f the manifest fo
3240: 72 20 74 68 69 73 20 63 68 61 6e 67 65 73 65 74 r this changeset
3250: 2e 0a 09 23 0a 09 23 20 44 61 74 61 20 6e 65 65 ...#..# Data nee
3260: 64 65 64 3a 0a 09 23 20 2d 20 43 6f 6d 6d 69 74 ded:..# - Commit
3270: 20 6d 65 73 73 61 67 65 20 20 20 20 20 20 20 20 message
3280: 20 20 20 20 20 20 20 28 2d 2d 20 6d 79 73 72 63 (-- mysrc
3290: 69 64 20 2d 3e 20 72 65 70 6f 73 69 74 6f 72 79 id -> repository
32a0: 20 6d 65 74 61 29 0a 09 23 20 2d 20 55 73 65 72 meta)..# - User
32b0: 20 64 6f 69 6e 67 20 74 68 65 20 63 6f 6d 6d 69 doing the commi
32c0: 74 20 20 20 20 20 20 20 20 28 73 2e 61 2e 29 0a t (s.a.).
32d0: 09 23 0a 09 23 20 2d 20 54 69 6d 65 73 74 61 6d .#..# - Timestam
32e0: 70 20 6f 66 20 77 68 65 6e 20 63 6f 6d 6d 69 74 p of when commit
32f0: 74 65 64 20 20 28 63 6f 6d 6d 61 6e 64 20 61 72 ted (command ar
3300: 67 75 6d 65 6e 74 29 0a 09 23 0a 09 23 20 2d 20 gument)..#..# -
3310: 54 68 65 20 70 61 72 65 6e 74 20 63 68 61 6e 67 The parent chang
3320: 65 73 65 74 2c 20 69 66 20 61 6e 79 2e 20 49 66 eset, if any. If
3330: 20 74 68 65 72 65 20 69 73 20 6e 6f 20 70 61 72 there is no par
3340: 65 6e 74 20 75 73 65 0a 09 23 20 20 20 74 68 65 ent use..# the
3350: 20 65 6d 70 74 79 20 62 61 73 65 20 72 65 76 69 empty base revi
3360: 73 69 6f 6e 20 61 73 20 70 61 72 65 6e 74 2e 0a sion as parent..
3370: 09 23 0a 09 23 20 2d 20 4c 69 73 74 20 6f 66 20 .#..# - List of
3380: 74 68 65 20 66 69 6c 65 20 72 65 76 69 73 69 6f the file revisio
3390: 6e 73 20 69 6e 20 74 68 65 20 63 68 61 6e 67 65 ns in the change
33a0: 73 65 74 2e 0a 0a 09 73 74 72 75 63 74 3a 3a 6c set....struct::l
33b0: 69 73 74 20 61 73 73 69 67 6e 20 5b 24 6d 79 70 ist assign [$myp
33c0: 72 6f 6a 65 63 74 20 67 65 74 6d 65 74 61 20 24 roject getmeta $
33d0: 6d 79 73 72 63 69 64 5d 20 5f 5f 20 62 72 61 6e mysrcid] __ bran
33e0: 63 68 20 75 73 65 72 20 6d 65 73 73 61 67 65 0a ch user message.
33f0: 09 73 74 72 75 63 74 3a 3a 6c 69 73 74 20 61 73 .struct::list as
3400: 73 69 67 6e 20 24 62 72 61 6e 63 68 20 5f 5f 20 sign $branch __
3410: 6c 6f 64 6e 61 6d 65 0a 0a 09 23 20 54 68 65 20 lodname...# The
3420: 70 61 72 65 6e 74 20 69 73 20 64 65 74 65 72 6d parent is determ
3430: 69 6e 65 64 20 76 69 61 20 74 68 65 20 6c 69 6e ined via the lin
3440: 65 2d 6f 66 2d 64 65 76 65 6c 6f 70 6d 65 6e 74 e-of-development
3450: 20 28 4c 4f 44 29 0a 09 23 20 69 6e 66 6f 72 6d (LOD)..# inform
3460: 61 74 69 6f 6e 20 6f 66 20 65 61 63 68 20 63 68 ation of each ch
3470: 61 6e 67 65 73 65 74 2c 20 61 6e 64 20 74 68 65 angeset, and the
3480: 20 68 69 73 74 6f 72 79 20 6f 66 0a 09 23 20 69 history of..# i
3490: 6d 70 6f 72 74 73 2e 20 54 68 65 20 6c 61 73 74 mports. The last
34a0: 20 63 68 61 6e 67 65 73 65 74 20 63 6f 6d 6d 69 changeset commi
34b0: 74 74 65 64 20 74 6f 20 74 68 65 20 73 61 6d 65 tted to the same
34c0: 20 4c 4f 44 20 69 73 0a 09 23 20 74 61 6b 65 6e LOD is..# taken
34d0: 20 61 73 20 74 68 65 20 70 61 72 65 6e 74 20 6f as the parent o
34e0: 66 20 74 68 65 20 63 75 72 72 65 6e 74 20 63 68 f the current ch
34f0: 61 6e 67 65 73 65 74 2e 20 49 66 20 74 68 65 0a angeset. If the.
3500: 09 23 20 63 68 61 6e 67 65 73 65 74 20 69 73 20 .# changeset is
3510: 74 68 65 20 66 69 72 73 74 20 6f 6e 20 74 68 61 the first on tha
3520: 74 20 4c 4f 44 20 69 74 20 63 61 6e 20 62 65 20 t LOD it can be
3530: 65 69 74 68 65 72 20 73 70 61 77 6e 65 64 0a 09 either spawned..
3540: 23 20 66 72 6f 6d 20 61 6e 6f 74 68 65 72 20 4c # from another L
3550: 4f 44 2c 20 6f 72 20 64 65 74 61 63 68 65 64 2e OD, or detached.
3560: 20 46 6f 72 20 74 68 65 20 66 69 72 73 74 20 63 For the first c
3570: 61 73 65 20 77 65 0a 09 23 20 72 65 74 72 69 65 ase we..# retrie
3580: 76 65 20 74 68 65 20 70 61 72 65 6e 74 20 4c 4f ve the parent LO
3590: 44 20 6f 66 20 74 68 65 20 63 75 72 72 65 6e 74 D of the current
35a0: 20 4c 4f 44 20 73 79 6d 62 6f 6c 20 28 2a 29 20 LOD symbol (*)
35b0: 61 6e 64 0a 09 23 20 72 65 63 68 65 63 6b 20 66 and..# recheck f
35c0: 6f 72 20 61 20 63 6f 6d 6d 69 74 74 65 64 20 63 or a committed c
35d0: 68 61 6e 67 65 73 65 74 2e 20 54 68 65 20 73 65 hangeset. The se
35e0: 63 6f 6e 64 20 63 61 73 65 20 69 73 20 74 61 6b cond case is tak
35f0: 65 6e 0a 09 23 20 69 66 20 74 68 61 74 20 6c 6f en..# if that lo
3600: 6f 6b 75 70 20 66 61 69 6c 73 20 61 73 20 77 65 okup fails as we
3610: 6c 6c 2e 0a 09 23 0a 09 23 20 28 2a 29 20 41 6e ll...#..# (*) An
3620: 64 20 74 68 69 73 20 70 61 72 65 6e 74 20 77 61 d this parent wa
3630: 73 20 66 6f 75 6e 64 20 69 6e 20 70 72 65 76 69 s found in previ
3640: 6f 75 73 20 70 61 73 73 65 73 20 77 68 65 6e 0a ous passes when.
3650: 09 23 20 20 20 20 20 64 65 74 65 72 6d 69 6e 69 .# determini
3660: 6e 67 20 74 68 65 20 70 72 65 66 65 72 65 64 20 ng the prefered
3670: 70 61 72 65 6e 74 73 20 6f 66 20 61 6c 6c 20 74 parents of all t
3680: 68 65 20 73 79 6d 62 6f 6c 73 2e 0a 0a 09 23 20 he symbols....#
3690: 4e 4f 54 45 3a 20 54 68 65 20 61 62 6f 76 65 20 NOTE: The above
36a0: 69 73 20 69 6e 63 6f 6d 70 6c 65 74 65 20 61 6e is incomplete an
36b0: 64 20 62 75 67 67 79 2e 20 56 65 6e 64 6f 72 2d d buggy. Vendor-
36c0: 62 72 61 6e 63 68 65 73 20 61 6e 64 0a 09 23 20 branches and..#
36d0: 20 20 20 20 20 20 74 68 65 20 76 61 72 69 6f 75 the variou
36e0: 73 20 70 6f 73 73 69 62 69 6c 69 74 69 65 73 20 s possibilities
36f0: 6f 66 20 69 74 73 20 69 6e 74 65 72 61 63 74 69 of its interacti
3700: 6f 6e 20 77 69 74 68 20 74 68 65 0a 09 23 20 20 on with the..#
3710: 20 20 20 20 20 74 72 75 6e 6b 20 61 72 65 20 6e trunk are n
3720: 6f 74 20 66 75 6c 6c 79 20 68 61 6e 64 6c 65 64 ot fully handled
3730: 2e 0a 0a 09 69 66 20 7b 5b 69 6e 66 6f 20 65 78 ....if {[info ex
3740: 69 73 74 73 20 73 74 61 74 65 28 24 6c 6f 64 6e ists state($lodn
3750: 61 6d 65 29 5d 7d 20 7b 0a 09 20 20 20 20 23 20 ame)]} {.. #
3760: 4c 4f 44 20 65 78 69 73 74 73 20 61 6e 64 20 68 LOD exists and h
3770: 61 73 20 61 6c 72 65 61 64 79 20 62 65 65 6e 20 as already been
3780: 63 6f 6d 6d 69 74 74 65 64 20 74 6f 2e 0a 09 20 committed to...
3790: 20 20 20 73 65 74 20 70 61 72 65 6e 74 20 24 73 set parent $s
37a0: 74 61 74 65 28 24 6c 6f 64 6e 61 6d 65 29 0a 09 tate($lodname)..
37b0: 7d 20 65 6c 73 65 20 7b 0a 09 20 20 20 20 23 20 } else {.. #
37c0: 4c 4f 44 20 68 61 73 20 6e 6f 74 20 62 65 65 6e LOD has not been
37d0: 20 63 6f 6d 6d 69 74 74 65 64 20 74 6f 20 62 65 committed to be
37e0: 66 6f 72 65 2c 20 74 68 69 73 20 69 73 20 74 68 fore, this is th
37f0: 65 20 66 69 72 73 74 0a 09 20 20 20 20 23 20 74 e first.. # t
3800: 69 6d 65 2e 20 44 65 74 65 72 6d 69 6e 65 20 74 ime. Determine t
3810: 68 65 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 70 he name of the p
3820: 61 72 65 6e 74 20 4c 4f 44 2e 0a 0a 09 20 20 20 arent LOD....
3830: 20 73 65 74 20 70 6c 6f 64 6e 61 6d 65 20 5b 5b set plodname [[
3840: 5b 24 6d 79 70 72 6f 6a 65 63 74 20 67 65 74 73 [$myproject gets
3850: 79 6d 62 6f 6c 20 24 6c 6f 64 6e 61 6d 65 5d 20 ymbol $lodname]
3860: 70 61 72 65 6e 74 5d 20 6e 61 6d 65 5d 0a 0a 09 parent] name]...
3870: 20 20 20 20 69 66 20 7b 5b 69 6e 66 6f 20 65 78 if {[info ex
3880: 69 73 74 73 20 73 74 61 74 65 28 24 70 6c 6f 64 ists state($plod
3890: 6e 61 6d 65 29 5d 7d 20 7b 0a 09 09 23 20 54 68 name)]} {...# Th
38a0: 65 20 70 61 72 65 6e 74 61 6c 20 4c 4f 44 20 68 e parental LOD h
38b0: 61 73 20 62 65 65 6e 20 63 6f 6d 6d 69 74 74 65 as been committe
38c0: 64 20 74 6f 2c 20 74 61 6b 65 20 74 68 61 74 0a d to, take that.
38d0: 09 09 23 20 6c 61 73 74 20 63 68 61 6e 67 65 73 ..# last changes
38e0: 65 74 20 61 73 20 74 68 65 20 73 70 61 77 6e 70 et as the spawnp
38f0: 6f 69 6e 74 20 66 6f 72 20 74 68 65 20 6e 65 77 oint for the new
3900: 20 4c 4f 44 2e 0a 09 09 73 65 74 20 70 61 72 65 LOD....set pare
3910: 6e 74 20 24 73 74 61 74 65 28 24 70 6c 6f 64 6e nt $state($plodn
3920: 61 6d 65 29 0a 09 20 20 20 20 7d 20 65 6c 73 65 ame).. } else
3930: 20 7b 0a 09 09 23 20 54 68 65 20 70 61 72 65 6e {...# The paren
3940: 74 61 6c 20 4c 4f 44 20 69 73 20 6e 6f 74 20 64 tal LOD is not d
3950: 65 66 69 6e 65 64 20 28 79 65 74 29 2e 20 54 68 efined (yet). Th
3960: 69 73 20 4c 4f 44 20 69 73 0a 09 09 23 20 64 65 is LOD is...# de
3970: 74 61 63 68 65 64 2e 20 57 65 20 63 68 6f 6f 73 tached. We choos
3980: 65 20 61 73 20 6f 75 72 20 70 61 72 65 6e 74 20 e as our parent
3990: 74 68 65 20 61 75 74 6f 6d 61 74 69 63 0a 09 09 the automatic...
39a0: 23 20 65 6d 70 74 79 20 72 6f 6f 74 20 62 61 73 # empty root bas
39b0: 65 6c 69 6e 65 20 6f 66 20 74 68 65 20 74 61 72 eline of the tar
39c0: 67 65 74 20 72 65 70 6f 73 69 74 6f 72 79 2e 0a get repository..
39d0: 09 09 73 65 74 20 70 61 72 65 6e 74 20 7b 7d 0a ..set parent {}.
39e0: 09 20 20 20 20 7d 0a 09 7d 0a 0a 09 23 20 50 65 . }..}...# Pe
39f0: 72 66 6f 72 6d 20 74 68 65 20 69 6d 70 6f 72 74 rform the import
3a00: 2e 20 41 73 20 70 61 72 74 20 6f 66 20 74 68 61 . As part of tha
3a10: 74 20 63 6f 6e 76 65 72 74 20 74 68 65 20 6c 69 t convert the li
3a20: 73 74 20 6f 66 0a 09 23 20 69 74 65 6d 73 20 69 st of..# items i
3a30: 6e 20 74 68 65 20 63 68 61 6e 67 65 73 65 74 20 n the changeset
3a40: 69 6e 74 6f 20 75 75 69 64 73 20 61 6e 64 20 70 into uuids and p
3a50: 72 69 6e 74 61 62 6c 65 20 64 61 74 61 2e 0a 0a rintable data...
3a60: 09 73 65 74 20 74 68 65 73 65 74 20 28 27 5b 6a .set theset ('[j
3a70: 6f 69 6e 20 24 6d 79 69 74 65 6d 73 20 7b 27 2c oin $myitems {',
3a80: 27 7d 5d 27 29 0a 09 73 65 74 20 75 75 69 64 20 '}]')..set uuid
3a90: 5b 24 72 65 70 6f 73 69 74 6f 72 79 20 69 6d 70 [$repository imp
3aa0: 6f 72 74 72 65 76 69 73 69 6f 6e 20 5b 24 73 65 ortrevision [$se
3ab0: 6c 66 20 73 74 72 5d 20 5c 0a 09 09 20 20 20 20 lf str] \...
3ac0: 20 20 24 75 73 65 72 20 24 6d 65 73 73 61 67 65 $user $message
3ad0: 20 24 64 61 74 65 20 24 70 61 72 65 6e 74 20 5c $date $parent \
3ae0: 0a 09 09 20 20 20 20 20 20 5b 73 74 61 74 65 20 ... [state
3af0: 72 75 6e 20 5b 73 75 62 73 74 20 2d 6e 6f 63 6f run [subst -noco
3b00: 6d 6d 61 6e 64 73 20 2d 6e 6f 62 61 63 6b 73 6c mmands -nobacksl
3b10: 61 73 68 65 73 20 7b 0a 09 09 09 20 20 53 45 4c ashes {.... SEL
3b20: 45 43 54 20 55 2e 75 75 69 64 2c 20 46 2e 6e 61 ECT U.uuid, F.na
3b30: 6d 65 2c 20 52 2e 72 65 76 0a 09 09 09 20 20 46 me, R.rev.... F
3b40: 52 4f 4d 20 20 20 72 65 76 69 73 69 6f 6e 20 52 ROM revision R
3b50: 2c 20 72 65 76 75 75 69 64 20 55 2c 20 66 69 6c , revuuid U, fil
3b60: 65 20 46 0a 09 09 09 20 20 57 48 45 52 45 20 20 e F.... WHERE
3b70: 52 2e 72 69 64 20 49 4e 20 24 74 68 65 73 65 74 R.rid IN $theset
3b80: 20 20 2d 2d 20 41 6c 6c 20 73 70 65 63 69 66 69 -- All specifi
3b90: 65 64 20 72 65 76 69 73 69 6f 6e 73 0a 09 09 09 ed revisions....
3ba0: 20 20 41 4e 44 20 20 20 20 55 2e 72 69 64 20 3d AND U.rid =
3bb0: 20 52 2e 72 69 64 20 20 20 20 20 2d 2d 20 67 65 R.rid -- ge
3bc0: 74 20 66 6f 73 73 69 6c 20 75 75 69 64 20 6f 66 t fossil uuid of
3bd0: 20 72 65 76 69 73 69 6f 6e 0a 09 09 09 20 20 41 revision.... A
3be0: 4e 44 20 20 20 20 46 2e 66 69 64 20 3d 20 52 2e ND F.fid = R.
3bf0: 66 69 64 20 20 20 20 20 2d 2d 20 67 65 74 20 66 fid -- get f
3c00: 69 6c 65 20 6f 66 20 72 65 76 69 73 69 6f 6e 0a ile of revision.
3c10: 09 09 20 20 20 20 20 20 7d 5d 5d 5d 0a 0a 09 23 .. }]]]...#
3c20: 20 52 65 6d 65 6d 62 65 72 20 74 68 65 20 69 6d Remember the im
3c30: 70 6f 72 74 65 64 20 63 68 61 6e 67 65 73 65 74 ported changeset
3c40: 20 69 6e 20 74 68 65 20 73 74 61 74 65 2c 20 75 in the state, u
3c50: 6e 64 65 72 20 6f 75 72 20 4c 4f 44 2e 0a 0a 09 nder our LOD....
3c60: 73 65 74 20 73 74 61 74 65 28 24 6c 6f 64 6e 61 set state($lodna
3c70: 6d 65 29 20 24 75 75 69 64 0a 0a 09 23 20 52 65 me) $uuid...# Re
3c80: 6d 65 6d 62 65 72 20 74 68 65 20 77 68 6f 6c 65 member the whole
3c90: 20 63 68 61 6e 67 65 73 65 74 20 2f 20 75 75 69 changeset / uui
3ca0: 64 20 6d 61 70 70 69 6e 67 2c 20 66 6f 72 20 74 d mapping, for t
3cb0: 68 65 20 74 61 67 73 2e 0a 0a 09 73 74 61 74 65 he tags....state
3cc0: 20 72 75 6e 20 7b 0a 09 20 20 20 20 49 4e 53 45 run {.. INSE
3cd0: 52 54 20 49 4e 54 4f 20 63 73 75 75 69 64 20 28 RT INTO csuuid (
3ce0: 63 69 64 2c 20 20 20 75 75 69 64 29 0a 09 20 20 cid, uuid)..
3cf0: 20 20 56 41 4c 55 45 53 20 20 20 20 20 20 20 20 VALUES
3d00: 20 20 20 20 20 28 24 6d 79 69 64 2c 20 24 75 75 ($myid, $uu
3d10: 69 64 29 0a 09 7d 0a 09 72 65 74 75 72 6e 0a 20 id)..}..return.
3d20: 20 20 20 7d 0a 0a 20 20 20 20 74 79 70 65 6d 65 }.. typeme
3d30: 74 68 6f 64 20 73 70 6c 69 74 20 7b 63 73 65 74 thod split {cset
3d40: 20 61 72 67 73 7d 20 7b 0a 09 23 20 41 73 20 70 args} {..# As p
3d50: 61 72 74 20 6f 66 20 74 68 65 20 63 72 65 61 74 art of the creat
3d60: 69 6f 6e 20 6f 66 20 74 68 65 20 6e 65 77 20 63 ion of the new c
3d70: 68 61 6e 67 65 73 65 74 73 20 73 70 65 63 69 66 hangesets specif
3d80: 69 65 64 20 69 6e 0a 09 23 20 41 52 47 53 20 61 ied in..# ARGS a
3d90: 73 20 73 65 74 73 20 6f 66 20 69 74 65 6d 73 2c s sets of items,
3da0: 20 61 6c 6c 20 73 75 62 73 65 74 73 20 6f 66 20 all subsets of
3db0: 43 53 45 54 27 73 20 69 74 65 6d 20 73 65 74 2c CSET's item set,
3dc0: 20 43 53 45 54 0a 09 23 20 77 69 6c 6c 20 62 65 CSET..# will be
3dd0: 20 64 72 6f 70 70 65 64 20 66 72 6f 6d 20 61 6c dropped from al
3de0: 6c 20 64 61 74 61 62 61 73 65 73 2c 20 69 6e 20 l databases, in
3df0: 61 6e 64 20 6f 75 74 20 6f 66 20 6d 65 6d 6f 72 and out of memor
3e00: 79 2c 0a 09 23 20 61 6e 64 20 74 68 65 6e 20 64 y,..# and then d
3e10: 65 73 74 72 6f 79 65 64 2e 0a 09 23 0a 09 23 20 estroyed...#..#
3e20: 4e 6f 74 65 3a 20 54 68 65 20 69 74 65 6d 20 6c Note: The item l
3e30: 69 73 74 73 20 66 6f 75 6e 64 20 69 6e 20 61 72 ists found in ar
3e40: 67 73 20 61 72 65 20 74 61 67 67 65 64 20 69 74 gs are tagged it
3e50: 65 6d 73 2e 20 54 68 65 79 0a 09 23 20 68 61 76 ems. They..# hav
3e60: 65 20 74 6f 20 68 61 76 65 20 74 68 65 20 73 61 e to have the sa
3e70: 6d 65 20 74 79 70 65 20 61 73 20 74 68 65 20 63 me type as the c
3e80: 68 61 6e 67 65 73 65 74 2c 20 62 65 69 6e 67 20 hangeset, being
3e90: 73 75 62 73 65 74 73 0a 09 23 20 6f 66 20 69 74 subsets..# of it
3ea0: 73 20 69 74 65 6d 73 2e 20 54 68 69 73 20 69 73 s items. This is
3eb0: 20 63 68 65 63 6b 65 64 20 69 6e 20 55 6e 74 61 checked in Unta
3ec0: 67 31 2e 0a 0a 09 6c 6f 67 20 77 72 69 74 65 20 g1....log write
3ed0: 38 20 63 73 65 74 73 20 7b 4f 4c 44 3a 20 5b 6c 8 csets {OLD: [l
3ee0: 73 6f 72 74 20 5b 24 63 73 65 74 20 69 74 65 6d sort [$cset item
3ef0: 73 5d 5d 7d 0a 09 56 61 6c 69 64 61 74 65 46 72 s]]}..ValidateFr
3f00: 61 67 6d 65 6e 74 73 20 24 63 73 65 74 20 24 61 agments $cset $a
3f10: 72 67 73 0a 0a 09 23 20 41 6c 6c 20 63 68 65 63 rgs...# All chec
3f20: 6b 73 20 70 61 73 73 2c 20 61 63 74 75 61 6c 6c ks pass, actuall
3f30: 79 20 70 65 72 66 6f 72 6d 20 74 68 65 20 73 70 y perform the sp
3f40: 6c 69 74 2e 0a 0a 09 73 74 72 75 63 74 3a 3a 6c lit....struct::l
3f50: 69 73 74 20 61 73 73 69 67 6e 20 5b 24 63 73 65 ist assign [$cse
3f60: 74 20 64 61 74 61 5d 20 70 72 6f 6a 65 63 74 20 t data] project
3f70: 63 73 74 79 70 65 20 63 73 73 72 63 0a 0a 09 73 cstype cssrc...s
3f80: 65 74 20 70 72 65 64 65 63 65 73 73 6f 72 73 20 et predecessors
3f90: 5b 24 63 73 65 74 20 64 72 6f 70 5d 0a 09 24 63 [$cset drop]..$c
3fa0: 73 65 74 20 64 65 73 74 72 6f 79 0a 0a 09 73 65 set destroy...se
3fb0: 74 20 6e 65 77 63 73 65 74 73 20 7b 7d 0a 09 66 t newcsets {}..f
3fc0: 6f 72 65 61 63 68 20 66 72 61 67 6d 65 6e 74 69 oreach fragmenti
3fd0: 74 65 6d 73 20 24 61 72 67 73 20 7b 0a 09 20 20 tems $args {..
3fe0: 20 20 6c 6f 67 20 77 72 69 74 65 20 38 20 63 73 log write 8 cs
3ff0: 65 74 73 20 7b 4d 41 4b 45 3a 20 5b 6c 73 6f 72 ets {MAKE: [lsor
4000: 74 20 24 66 72 61 67 6d 65 6e 74 69 74 65 6d 73 t $fragmentitems
4010: 5d 7d 0a 0a 09 20 20 20 20 73 65 74 20 66 72 61 ]}... set fra
4020: 67 6d 65 6e 74 20 5b 24 74 79 70 65 20 25 41 55 gment [$type %AU
4030: 54 4f 25 20 24 70 72 6f 6a 65 63 74 20 24 63 73 TO% $project $cs
4040: 74 79 70 65 20 24 63 73 73 72 63 20 5c 0a 09 09 type $cssrc \...
4050: 09 20 20 20 20 20 20 5b 55 6e 74 61 67 20 24 66 . [Untag $f
4060: 72 61 67 6d 65 6e 74 69 74 65 6d 73 20 24 63 73 ragmentitems $cs
4070: 74 79 70 65 5d 5d 0a 09 20 20 20 20 6c 61 70 70 type]].. lapp
4080: 65 6e 64 20 6e 65 77 63 73 65 74 73 20 24 66 72 end newcsets $fr
4090: 61 67 6d 65 6e 74 0a 0a 09 20 20 20 20 24 66 72 agment... $fr
40a0: 61 67 6d 65 6e 74 20 70 65 72 73 69 73 74 0a 09 agment persist..
40b0: 20 20 20 20 24 66 72 61 67 6d 65 6e 74 20 64 65 $fragment de
40c0: 74 65 72 6d 69 6e 65 73 75 63 63 65 73 73 6f 72 terminesuccessor
40d0: 73 0a 09 7d 0a 0a 09 23 20 54 68 65 20 70 72 65 s..}...# The pre
40e0: 64 65 63 65 73 73 6f 72 73 20 68 61 76 65 20 74 decessors have t
40f0: 6f 20 72 65 63 6f 6d 70 75 74 65 20 74 68 65 69 o recompute thei
4100: 72 20 73 75 63 63 65 73 73 6f 72 73 2c 20 69 2e r successors, i.
4110: 65 2e 0a 09 23 20 72 65 6d 6f 76 65 20 74 68 65 e...# remove the
4120: 20 64 72 6f 70 70 65 64 20 63 68 61 6e 67 65 73 dropped changes
4130: 65 74 20 61 6e 64 20 70 75 74 20 6f 6e 65 20 6f et and put one o
4140: 66 20 74 68 65 20 66 72 61 67 6d 65 6e 74 73 0a f the fragments.
4150: 09 23 20 69 6e 74 6f 20 69 74 73 20 70 6c 61 63 .# into its plac
4160: 65 2e 0a 09 66 6f 72 65 61 63 68 20 70 20 24 70 e...foreach p $p
4170: 72 65 64 65 63 65 73 73 6f 72 73 20 7b 0a 09 20 redecessors {..
4180: 20 20 20 24 70 20 64 65 74 65 72 6d 69 6e 65 73 $p determines
4190: 75 63 63 65 73 73 6f 72 73 0a 09 7d 0a 0a 09 72 uccessors..}...r
41a0: 65 74 75 72 6e 20 24 6e 65 77 63 73 65 74 73 0a eturn $newcsets.
41b0: 20 20 20 20 7d 0a 0a 20 20 20 20 74 79 70 65 6d }.. typem
41c0: 65 74 68 6f 64 20 69 74 65 6d 73 74 72 20 7b 69 ethod itemstr {i
41d0: 74 65 6d 7d 20 7b 0a 09 73 74 72 75 63 74 3a 3a tem} {..struct::
41e0: 6c 69 73 74 20 61 73 73 69 67 6e 20 24 69 74 65 list assign $ite
41f0: 6d 20 69 74 79 70 65 20 69 69 64 0a 09 72 65 74 m itype iid..ret
4200: 75 72 6e 20 5b 24 69 74 79 70 65 20 73 74 72 20 urn [$itype str
4210: 24 69 69 64 5d 0a 20 20 20 20 7d 0a 0a 20 20 20 $iid]. }..
4220: 20 74 79 70 65 6d 65 74 68 6f 64 20 73 74 72 6c typemethod strl
4230: 69 73 74 20 7b 63 68 61 6e 67 65 73 65 74 73 7d ist {changesets}
4240: 20 7b 0a 09 72 65 74 75 72 6e 20 5b 6a 6f 69 6e {..return [join
4250: 20 5b 73 74 72 75 63 74 3a 3a 6c 69 73 74 20 6d [struct::list m
4260: 61 70 20 24 63 68 61 6e 67 65 73 65 74 73 20 5b ap $changesets [
4270: 6d 79 70 72 6f 63 20 49 44 5d 5d 5d 0a 20 20 20 myproc ID]]].
4280: 20 7d 0a 0a 20 20 20 20 70 72 6f 63 20 49 44 20 }.. proc ID
4290: 7b 63 73 65 74 7d 20 7b 20 24 63 73 65 74 20 73 {cset} { $cset s
42a0: 74 72 20 7d 0a 0a 20 20 20 20 70 72 6f 63 20 55 tr }.. proc U
42b0: 6e 74 61 67 20 7b 74 61 67 67 65 64 69 74 65 6d ntag {taggeditem
42c0: 73 20 63 73 74 79 70 65 7d 20 7b 0a 09 72 65 74 s cstype} {..ret
42d0: 75 72 6e 20 5b 73 74 72 75 63 74 3a 3a 6c 69 73 urn [struct::lis
42e0: 74 20 6d 61 70 20 24 74 61 67 67 65 64 69 74 65 t map $taggedite
42f0: 6d 73 20 5b 6d 79 70 72 6f 63 20 55 6e 74 61 67 ms [myproc Untag
4300: 31 20 24 63 73 74 79 70 65 5d 5d 0a 20 20 20 20 1 $cstype]].
4310: 7d 0a 0a 20 20 20 20 70 72 6f 63 20 55 6e 74 61 }.. proc Unta
4320: 67 31 20 7b 63 73 74 79 70 65 20 74 68 65 69 74 g1 {cstype theit
4330: 65 6d 7d 20 7b 0a 09 73 74 72 75 63 74 3a 3a 6c em} {..struct::l
4340: 69 73 74 20 61 73 73 69 67 6e 20 24 74 68 65 69 ist assign $thei
4350: 74 65 6d 20 74 20 69 0a 09 69 6e 74 65 67 72 69 tem t i..integri
4360: 74 79 20 61 73 73 65 72 74 20 7b 24 63 73 74 79 ty assert {$csty
4370: 70 65 20 65 71 20 24 74 7d 20 7b 49 74 65 6d 20 pe eq $t} {Item
4380: 24 69 27 73 20 74 79 70 65 20 69 73 20 27 24 74 $i's type is '$t
4390: 27 2c 20 65 78 70 65 63 74 65 64 20 27 24 63 73 ', expected '$cs
43a0: 74 79 70 65 27 7d 0a 09 72 65 74 75 72 6e 20 24 type'}..return $
43b0: 69 0a 20 20 20 20 7d 0a 0a 20 20 20 20 70 72 6f i. }.. pro
43c0: 63 20 54 61 67 49 74 65 6d 44 69 63 74 20 7b 69 c TagItemDict {i
43d0: 74 65 6d 64 69 63 74 20 63 73 74 79 70 65 7d 20 temdict cstype}
43e0: 7b 0a 09 73 65 74 20 72 65 73 20 7b 7d 0a 09 66 {..set res {}..f
43f0: 6f 72 65 61 63 68 20 7b 69 20 76 7d 20 24 69 74 oreach {i v} $it
4400: 65 6d 64 69 63 74 20 7b 20 6c 61 70 70 65 6e 64 emdict { lappend
4410: 20 72 65 73 20 5b 6c 69 73 74 20 24 63 73 74 79 res [list $csty
4420: 70 65 20 24 69 5d 20 24 76 20 7d 0a 09 72 65 74 pe $i] $v }..ret
4430: 75 72 6e 20 24 72 65 73 0a 20 20 20 20 7d 0a 0a urn $res. }..
4440: 20 20 20 20 70 72 6f 63 20 56 61 6c 69 64 61 74 proc Validat
4450: 65 46 72 61 67 6d 65 6e 74 73 20 7b 63 73 65 74 eFragments {cset
4460: 20 66 72 61 67 6d 65 6e 74 73 7d 20 7b 0a 09 23 fragments} {..#
4470: 20 43 68 65 63 6b 20 74 68 65 20 76 61 72 69 6f Check the vario
4480: 75 73 20 69 6e 74 65 67 72 69 74 79 20 63 6f 6e us integrity con
4490: 73 74 72 61 69 6e 74 73 20 66 6f 72 20 74 68 65 straints for the
44a0: 20 66 72 61 67 6d 65 6e 74 73 0a 09 23 20 73 70 fragments..# sp
44b0: 65 63 69 66 79 69 6e 67 20 68 6f 77 20 74 6f 20 ecifying how to
44c0: 73 70 6c 69 74 20 74 68 65 20 63 68 61 6e 67 65 split the change
44d0: 73 65 74 3a 0a 09 23 0a 09 23 20 2a 20 57 65 20 set:..#..# * We
44e0: 6d 75 73 74 20 68 61 76 65 20 74 77 6f 20 6f 72 must have two or
44f0: 20 6d 6f 72 65 20 66 72 61 67 6d 65 6e 74 73 2c more fragments,
4500: 20 61 73 20 73 70 6c 69 74 74 69 6e 67 20 61 0a as splitting a.
4510: 09 23 20 20 20 63 68 61 6e 67 65 73 65 74 20 69 .# changeset i
4520: 6e 74 6f 20 6f 6e 65 20 6d 61 6b 65 73 20 6e 6f nto one makes no
4530: 20 73 65 6e 73 65 2e 0a 09 23 20 2a 20 4e 6f 20 sense...# * No
4540: 66 72 61 67 6d 65 6e 74 20 6d 61 79 20 62 65 20 fragment may be
4550: 65 6d 70 74 79 2e 0a 09 23 20 2a 20 41 6c 6c 20 empty...# * All
4560: 66 72 61 67 6d 65 6e 74 73 20 68 61 76 65 20 74 fragments have t
4570: 6f 20 62 65 20 74 72 75 65 20 73 75 62 73 65 74 o be true subset
4580: 73 20 6f 66 20 74 68 65 20 69 74 65 6d 73 20 69 s of the items i
4590: 6e 20 74 68 65 0a 09 23 20 20 20 63 68 61 6e 67 n the..# chang
45a0: 65 73 65 74 20 74 6f 20 73 70 6c 69 74 2e 20 54 eset to split. T
45b0: 68 65 20 27 74 72 75 65 27 20 69 73 20 69 6d 70 he 'true' is imp
45c0: 6c 69 65 64 20 62 65 63 61 75 73 65 20 6e 6f 6e lied because non
45d0: 65 20 61 72 65 0a 09 23 20 20 20 61 6c 6c 6f 77 e are..# allow
45e0: 65 64 20 74 6f 20 62 65 20 65 6d 70 74 79 2c 20 ed to be empty,
45f0: 73 6f 20 65 61 63 68 20 68 61 73 20 74 6f 20 62 so each has to b
4600: 65 20 73 6d 61 6c 6c 65 72 20 74 68 61 6e 20 74 e smaller than t
4610: 68 65 0a 09 23 20 20 20 74 6f 74 61 6c 2e 0a 09 he..# total...
4620: 23 20 2a 20 54 68 65 20 75 6e 69 6f 6e 20 6f 66 # * The union of
4630: 20 74 68 65 20 66 72 61 67 6d 65 6e 74 73 20 68 the fragments h
4640: 61 73 20 74 6f 20 62 65 20 74 68 65 20 69 74 65 as to be the ite
4650: 6d 20 73 65 74 20 6f 66 20 74 68 65 0a 09 23 20 m set of the..#
4660: 20 20 63 68 61 6e 67 65 73 65 74 2e 0a 09 23 20 changeset...#
4670: 2a 20 54 68 65 20 66 72 61 67 6d 65 6e 74 20 6d * The fragment m
4680: 75 73 74 20 6e 6f 74 20 6f 76 65 72 6c 61 70 2c ust not overlap,
4690: 20 69 2e 65 2e 20 74 68 65 69 72 20 70 61 69 72 i.e. their pair
46a0: 77 69 73 65 0a 09 23 20 20 20 69 6e 74 65 72 73 wise..# inters
46b0: 65 63 74 69 6f 6e 73 20 68 61 76 65 20 74 6f 20 ections have to
46c0: 62 65 20 65 6d 70 74 79 2e 0a 0a 09 73 65 74 20 be empty....set
46d0: 63 6f 76 65 72 20 7b 7d 0a 09 66 6f 72 65 61 63 cover {}..foreac
46e0: 68 20 66 72 61 67 6d 65 6e 74 69 74 65 6d 73 20 h fragmentitems
46f0: 24 66 72 61 67 6d 65 6e 74 73 20 7b 0a 09 20 20 $fragments {..
4700: 20 20 6c 6f 67 20 77 72 69 74 65 20 38 20 63 73 log write 8 cs
4710: 65 74 73 20 7b 4e 45 57 3a 20 5b 6c 73 6f 72 74 ets {NEW: [lsort
4720: 20 24 66 72 61 67 6d 65 6e 74 69 74 65 6d 73 5d $fragmentitems]
4730: 7d 0a 0a 09 20 20 20 20 69 6e 74 65 67 72 69 74 }... integrit
4740: 79 20 61 73 73 65 72 74 20 7b 0a 09 09 21 5b 73 y assert {...![s
4750: 74 72 75 63 74 3a 3a 73 65 74 20 65 6d 70 74 79 truct::set empty
4760: 20 24 66 72 61 67 6d 65 6e 74 69 74 65 6d 73 5d $fragmentitems]
4770: 0a 09 20 20 20 20 7d 20 7b 63 68 61 6e 67 65 73 .. } {changes
4780: 65 74 20 66 72 61 67 6d 65 6e 74 20 69 73 20 65 et fragment is e
4790: 6d 70 74 79 7d 0a 0a 09 20 20 20 20 69 6e 74 65 mpty}... inte
47a0: 67 72 69 74 79 20 61 73 73 65 72 74 20 7b 0a 09 grity assert {..
47b0: 09 5b 73 74 72 75 63 74 3a 3a 73 65 74 20 73 75 .[struct::set su
47c0: 62 73 65 74 6f 66 20 24 66 72 61 67 6d 65 6e 74 bsetof $fragment
47d0: 69 74 65 6d 73 20 5b 24 63 73 65 74 20 69 74 65 items [$cset ite
47e0: 6d 73 5d 5d 0a 09 20 20 20 20 7d 20 7b 63 68 61 ms]].. } {cha
47f0: 6e 67 65 73 65 74 20 66 72 61 67 6d 65 6e 74 20 ngeset fragment
4800: 69 73 20 6e 6f 74 20 61 20 73 75 62 73 65 74 7d is not a subset}
4810: 0a 09 20 20 20 20 73 74 72 75 63 74 3a 3a 73 65 .. struct::se
4820: 74 20 61 64 64 20 63 6f 76 65 72 20 24 66 72 61 t add cover $fra
4830: 67 6d 65 6e 74 69 74 65 6d 73 0a 09 7d 0a 0a 09 gmentitems..}...
4840: 69 6e 74 65 67 72 69 74 79 20 61 73 73 65 72 74 integrity assert
4850: 20 7b 0a 09 20 20 20 20 5b 73 74 72 75 63 74 3a {.. [struct:
4860: 3a 73 65 74 20 65 71 75 61 6c 20 24 63 6f 76 65 :set equal $cove
4870: 72 20 5b 24 63 73 65 74 20 69 74 65 6d 73 5d 5d r [$cset items]]
4880: 0a 09 20 7d 20 7b 54 68 65 20 66 72 61 67 6d 65 .. } {The fragme
4890: 6e 74 73 20 64 6f 20 6e 6f 74 20 63 6f 76 65 72 nts do not cover
48a0: 20 74 68 65 20 6f 72 69 67 69 6e 61 6c 20 63 68 the original ch
48b0: 61 6e 67 65 73 65 74 7d 0a 0a 09 73 65 74 20 69 angeset}...set i
48c0: 20 31 0a 09 66 6f 72 65 61 63 68 20 66 69 61 20 1..foreach fia
48d0: 24 66 72 61 67 6d 65 6e 74 73 20 7b 0a 09 20 20 $fragments {..
48e0: 20 20 66 6f 72 65 61 63 68 20 66 69 62 20 5b 6c foreach fib [l
48f0: 72 61 6e 67 65 20 24 66 72 61 67 6d 65 6e 74 73 range $fragments
4900: 20 24 69 20 65 6e 64 5d 20 7b 0a 09 09 69 6e 74 $i end] {...int
4910: 65 67 72 69 74 79 20 61 73 73 65 72 74 20 7b 0a egrity assert {.
4920: 09 09 20 20 20 20 5b 73 74 72 75 63 74 3a 3a 73 .. [struct::s
4930: 65 74 20 65 6d 70 74 79 20 5b 73 74 72 75 63 74 et empty [struct
4940: 3a 3a 73 65 74 20 69 6e 74 65 72 73 65 63 74 20 ::set intersect
4950: 24 66 69 61 20 24 66 69 62 5d 5d 0a 09 09 7d 20 $fia $fib]]...}
4960: 7b 54 68 65 20 66 72 61 67 6d 65 6e 74 73 20 3c {The fragments <
4970: 24 66 69 61 3e 20 61 6e 64 20 3c 24 66 69 62 3e $fia> and <$fib>
4980: 20 6f 76 65 72 6c 61 70 7d 0a 09 20 20 20 20 7d overlap}.. }
4990: 0a 09 20 20 20 20 69 6e 63 72 20 69 0a 09 7d 0a .. incr i..}.
49a0: 0a 09 72 65 74 75 72 6e 0a 20 20 20 20 7d 0a 0a ..return. }..
49b0: 20 20 20 20 23 20 23 20 23 23 20 23 23 23 20 23 # # ## ### #
49c0: 23 23 23 23 20 23 23 23 23 23 23 23 23 20 23 23 #### ######## ##
49d0: 23 23 23 23 23 23 23 23 23 23 23 0a 20 20 20 20 ###########.
49e0: 23 23 20 53 74 61 74 65 0a 0a 20 20 20 20 76 61 ## State.. va
49f0: 72 69 61 62 6c 65 20 6d 79 69 64 20 20 20 20 20 riable myid
4a00: 20 20 20 7b 7d 20 3b 20 23 20 49 64 20 6f 66 20 {} ; # Id of
4a10: 74 68 65 20 63 73 65 74 20 66 6f 72 20 74 68 65 the cset for the
4a20: 20 70 65 72 73 69 73 74 65 6e 74 0a 09 09 09 20 persistent....
4a30: 20 20 20 20 20 23 20 73 74 61 74 65 2e 0a 20 20 # state..
4a40: 20 20 76 61 72 69 61 62 6c 65 20 6d 79 70 72 6f variable mypro
4a50: 6a 65 63 74 20 20 20 7b 7d 20 3b 20 23 20 52 65 ject {} ; # Re
4a60: 66 65 72 65 6e 63 65 20 6f 66 20 74 68 65 20 70 ference of the p
4a70: 72 6f 6a 65 63 74 20 6f 62 6a 65 63 74 20 74 68 roject object th
4a80: 65 0a 09 09 09 20 20 20 20 20 20 23 20 63 68 61 e.... # cha
4a90: 6e 67 65 73 65 74 20 62 65 6c 6f 6e 67 73 20 74 ngeset belongs t
4aa0: 6f 2e 0a 20 20 20 20 76 61 72 69 61 62 6c 65 20 o.. variable
4ab0: 6d 79 74 79 70 65 20 20 20 20 20 20 7b 7d 20 3b mytype {} ;
4ac0: 20 23 20 57 68 61 74 20 74 68 65 20 63 68 61 6e # What the chan
4ad0: 67 65 73 65 74 20 69 73 20 62 61 73 65 64 20 6f geset is based o
4ae0: 6e 0a 09 09 09 20 20 20 20 20 20 23 20 28 72 65 n.... # (re
4af0: 76 69 73 69 6f 6e 73 2c 20 74 61 67 73 2c 20 6f visions, tags, o
4b00: 72 20 62 72 61 6e 63 68 65 73 29 2e 0a 09 09 09 r branches).....
4b10: 20 20 20 20 20 20 23 20 56 61 6c 75 65 73 3a 20 # Values:
4b20: 53 65 65 20 6d 79 63 73 74 79 70 65 2e 20 4e 6f See mycstype. No
4b30: 74 65 20 74 68 61 74 20 77 65 0a 09 09 09 20 20 te that we....
4b40: 20 20 20 20 23 20 68 61 76 65 20 74 6f 20 6b 65 # have to ke
4b50: 65 70 20 74 68 65 20 6e 61 6d 65 73 20 6f 66 20 ep the names of
4b60: 74 68 65 20 68 65 6c 70 65 72 0a 09 09 09 20 20 the helper....
4b70: 20 20 20 20 23 20 73 69 6e 67 6c 65 74 6f 6e 73 # singletons
4b80: 20 69 6e 20 73 79 6e 63 20 77 69 74 68 20 74 68 in sync with th
4b90: 65 20 63 6f 6e 74 65 6e 74 73 0a 09 09 09 20 20 e contents....
4ba0: 20 20 20 20 23 20 6f 66 20 73 74 61 74 65 20 74 # of state t
4bb0: 61 62 6c 65 20 27 63 73 74 79 70 65 27 2c 20 61 able 'cstype', a
4bc0: 6e 64 20 76 61 72 69 6f 75 73 0a 09 09 09 20 20 nd various....
4bd0: 20 20 20 20 23 20 6f 74 68 65 72 20 70 6c 61 63 # other plac
4be0: 65 73 20 75 73 69 6e 67 20 74 68 65 6d 20 68 61 es using them ha
4bf0: 72 64 77 69 72 65 64 2e 0a 20 20 20 20 76 61 72 rdwired.. var
4c00: 69 61 62 6c 65 20 6d 79 74 79 70 65 6f 62 6a 20 iable mytypeobj
4c10: 20 20 7b 7d 20 3b 20 23 20 52 65 66 65 72 65 6e {} ; # Referen
4c20: 63 65 20 74 6f 20 74 68 65 20 63 6f 6e 74 61 69 ce to the contai
4c30: 6e 65 72 20 66 6f 72 20 74 68 65 0a 09 09 09 20 ner for the....
4c40: 20 20 20 20 20 23 20 74 79 70 65 20 64 65 70 65 # type depe
4c50: 6e 64 65 6e 74 20 63 6f 64 65 2e 20 44 65 72 69 ndent code. Deri
4c60: 76 65 64 20 66 72 6f 6d 0a 09 09 09 20 20 20 20 ved from....
4c70: 20 20 23 20 6d 79 74 79 70 65 2e 0a 20 20 20 20 # mytype..
4c80: 76 61 72 69 61 62 6c 65 20 6d 79 73 72 63 69 64 variable mysrcid
4c90: 20 20 20 20 20 7b 7d 20 3b 20 23 20 49 64 20 6f {} ; # Id o
4ca0: 66 20 74 68 65 20 6d 65 74 61 64 61 74 61 20 6f f the metadata o
4cb0: 72 20 73 79 6d 62 6f 6c 20 74 68 65 20 63 73 65 r symbol the cse
4cc0: 74 0a 09 09 09 20 20 20 20 20 20 23 20 69 73 20 t.... # is
4cd0: 62 61 73 65 64 20 6f 6e 2e 0a 20 20 20 20 76 61 based on.. va
4ce0: 72 69 61 62 6c 65 20 6d 79 69 74 65 6d 73 20 20 riable myitems
4cf0: 20 20 20 7b 7d 20 3b 20 23 20 4c 69 73 74 20 6f {} ; # List o
4d00: 66 20 74 68 65 20 66 69 6c 65 20 6c 65 76 65 6c f the file level
4d10: 20 72 65 76 69 73 69 6f 6e 73 2c 0a 09 09 09 20 revisions,....
4d20: 20 20 20 20 20 23 20 74 61 67 73 2c 20 6f 72 20 # tags, or
4d30: 62 72 61 6e 63 68 65 73 20 69 6e 20 74 68 65 20 branches in the
4d40: 63 73 65 74 2c 20 61 73 0a 09 09 09 20 20 20 20 cset, as....
4d50: 20 20 23 20 69 64 73 2e 20 4e 6f 74 20 74 61 67 # ids. Not tag
4d60: 67 65 64 2e 0a 20 20 20 20 76 61 72 69 61 62 6c ged.. variabl
4d70: 65 20 6d 79 74 69 74 65 6d 73 20 20 20 20 7b 7d e mytitems {}
4d80: 20 3b 20 23 20 41 73 20 6d 79 69 74 65 6d 73 2c ; # As myitems,
4d90: 20 74 68 65 20 74 61 67 67 65 64 20 66 6f 72 6d the tagged form
4da0: 2e 0a 20 20 20 20 76 61 72 69 61 62 6c 65 20 6d .. variable m
4db0: 79 70 6f 73 20 20 20 20 20 20 20 7b 7d 20 3b 20 ypos {} ;
4dc0: 23 20 43 6f 6d 6d 69 74 20 70 6f 73 69 74 69 6f # Commit positio
4dd0: 6e 20 6f 66 20 74 68 65 20 63 68 61 6e 67 65 73 n of the changes
4de0: 65 74 2c 20 69 66 0a 09 09 09 20 20 20 20 20 20 et, if....
4df0: 23 20 6b 6e 6f 77 6e 2e 0a 0a 20 20 20 20 23 20 # known... #
4e00: 23 20 23 23 20 23 23 23 20 23 23 23 23 23 20 23 # ## ### ##### #
4e10: 23 23 23 23 23 23 23 20 23 23 23 23 23 23 23 23 ####### ########
4e20: 23 23 23 23 23 0a 20 20 20 20 23 23 20 49 6e 74 #####. ## Int
4e30: 65 72 6e 61 6c 20 6d 65 74 68 6f 64 73 0a 0a 20 ernal methods..
4e40: 20 20 20 74 79 70 65 76 61 72 69 61 62 6c 65 20 typevariable
4e50: 6d 79 63 6f 75 6e 74 65 72 20 20 20 20 20 20 20 mycounter
4e60: 20 30 20 3b 20 23 20 49 64 20 63 6f 75 6e 74 65 0 ; # Id counte
4e70: 72 20 66 6f 72 20 63 73 65 74 73 2e 20 4c 61 73 r for csets. Las
4e80: 74 20 69 64 0a 09 09 09 09 20 20 20 20 20 20 23 t id..... #
4e90: 20 75 73 65 64 2e 0a 20 20 20 20 74 79 70 65 76 used.. typev
4ea0: 61 72 69 61 62 6c 65 20 6d 79 63 73 74 79 70 65 ariable mycstype
4eb0: 20 2d 61 72 72 61 79 20 7b 7d 20 3b 20 23 20 4d -array {} ; # M
4ec0: 61 70 20 63 73 74 79 70 65 73 20 28 6e 61 6d 65 ap cstypes (name
4ed0: 73 29 20 74 6f 20 70 65 72 73 69 73 74 65 6e 74 s) to persistent
4ee0: 0a 09 09 09 09 20 20 20 20 20 20 23 20 69 64 73 ..... # ids
4ef0: 2e 20 4e 6f 74 65 20 74 68 61 74 20 77 65 20 68 . Note that we h
4f00: 61 76 65 20 74 6f 20 6b 65 65 70 0a 09 09 09 09 ave to keep.....
4f10: 20 20 20 20 20 20 23 20 74 68 65 20 6e 61 6d 65 # the name
4f20: 73 20 69 6e 20 74 68 65 20 74 61 62 6c 65 20 27 s in the table '
4f30: 63 73 74 79 70 65 27 0a 09 09 09 09 20 20 20 20 cstype'.....
4f40: 20 20 23 20 69 6e 20 73 79 6e 63 20 77 69 74 68 # in sync with
4f50: 20 74 68 65 20 6e 61 6d 65 73 20 6f 66 20 74 68 the names of th
4f60: 65 0a 09 09 09 09 20 20 20 20 20 20 23 20 68 65 e..... # he
4f70: 6c 70 65 72 20 73 69 6e 67 6c 65 74 6f 6e 73 2e lper singletons.
4f80: 0a 0a 20 20 20 20 74 79 70 65 6d 65 74 68 6f 64 .. typemethod
4f90: 20 69 6e 6f 72 64 65 72 20 7b 70 72 6f 6a 65 63 inorder {projec
4fa0: 74 69 64 7d 20 7b 0a 09 23 20 52 65 74 75 72 6e tid} {..# Return
4fb0: 20 61 6c 6c 20 72 65 76 69 73 69 6f 6e 20 63 68 all revision ch
4fc0: 61 6e 67 65 73 65 74 73 20 66 6f 72 20 74 68 65 angesets for the
4fd0: 20 73 70 65 63 69 66 69 65 64 20 70 72 6f 6a 65 specified proje
4fe0: 63 74 2c 20 69 6e 0a 09 23 20 74 68 65 20 6f 72 ct, in..# the or
4ff0: 64 65 72 20 67 69 76 65 6e 20 74 6f 20 74 68 65 der given to the
5000: 6d 20 62 79 20 74 68 65 20 73 6f 72 74 20 70 61 m by the sort pa
5010: 73 73 65 73 2e 20 42 6f 74 68 20 74 68 65 0a 09 sses. Both the..
5020: 23 20 66 69 6c 74 65 72 69 6e 67 20 62 79 20 70 # filtering by p
5030: 72 6f 6a 65 63 74 20 61 6e 64 20 73 6f 72 74 69 roject and sorti
5040: 6e 67 20 6d 61 6b 65 20 75 73 65 20 6f 66 20 27 ng make use of '
5050: 70 72 6f 6a 65 63 74 3a 3a 72 65 76 0a 09 23 20 project::rev..#
5060: 72 65 76 27 20 69 6d 70 6f 73 73 69 62 6c 65 2e rev' impossible.
5070: 0a 0a 09 73 65 74 20 72 65 73 20 7b 7d 0a 09 66 ...set res {}..f
5080: 6f 72 65 61 63 68 20 7b 63 69 64 20 63 64 61 74 oreach {cid cdat
5090: 65 7d 20 5b 73 74 61 74 65 20 72 75 6e 20 7b 0a e} [state run {.
50a0: 09 20 20 20 20 53 45 4c 45 43 54 20 43 2e 63 69 . SELECT C.ci
50b0: 64 2c 20 54 2e 64 61 74 65 0a 09 20 20 20 20 46 d, T.date.. F
50c0: 52 4f 4d 20 20 20 63 68 61 6e 67 65 73 65 74 20 ROM changeset
50d0: 43 2c 20 63 73 74 69 6d 65 73 74 61 6d 70 20 54 C, cstimestamp T
50e0: 0a 09 20 20 20 20 57 48 45 52 45 20 20 43 2e 74 .. WHERE C.t
50f0: 79 70 65 20 3d 20 30 20 20 20 20 20 20 20 20 20 ype = 0
5100: 20 2d 2d 20 6c 69 6d 69 74 20 74 6f 20 72 65 76 -- limit to rev
5110: 69 73 69 6f 6e 20 63 68 61 6e 67 65 73 65 74 73 ision changesets
5120: 0a 09 20 20 20 20 41 4e 44 20 20 20 20 43 2e 70 .. AND C.p
5130: 69 64 20 20 3d 20 24 70 72 6f 6a 65 63 74 69 64 id = $projectid
5140: 20 2d 2d 20 6c 69 6d 69 74 20 74 6f 20 63 68 61 -- limit to cha
5150: 6e 67 65 73 65 74 73 20 69 6e 20 70 72 6f 6a 65 ngesets in proje
5160: 63 74 0a 09 20 20 20 20 41 4e 44 20 20 20 20 54 ct.. AND T
5170: 2e 63 69 64 20 20 3d 20 43 2e 63 69 64 20 20 20 .cid = C.cid
5180: 20 20 20 2d 2d 20 67 65 74 20 6f 72 64 65 72 69 -- get orderi
5190: 6e 67 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 0a 09 ng information..
51a0: 20 20 20 20 4f 52 44 45 52 20 42 59 20 54 2e 64 ORDER BY T.d
51b0: 61 74 65 20 20 20 20 20 20 20 20 20 20 20 20 2d ate -
51c0: 2d 20 73 6f 72 74 20 69 6e 74 6f 20 63 6f 6d 6d - sort into comm
51d0: 69 74 20 6f 72 64 65 72 0a 09 7d 5d 20 7b 0a 09 it order..}] {..
51e0: 20 20 20 20 6c 61 70 70 65 6e 64 20 72 65 73 20 lappend res
51f0: 24 6d 79 69 64 6d 61 70 28 24 63 69 64 29 20 24 $myidmap($cid) $
5200: 63 64 61 74 65 0a 09 7d 0a 09 72 65 74 75 72 6e cdate..}..return
5210: 20 24 72 65 73 0a 20 20 20 20 7d 0a 0a 20 20 20 $res. }..
5220: 20 74 79 70 65 6d 65 74 68 6f 64 20 67 65 74 63 typemethod getc
5230: 73 74 79 70 65 73 20 7b 7d 20 7b 0a 09 66 6f 72 stypes {} {..for
5240: 65 61 63 68 20 7b 74 69 64 20 6e 61 6d 65 7d 20 each {tid name}
5250: 5b 73 74 61 74 65 20 72 75 6e 20 7b 0a 09 20 20 [state run {..
5260: 20 20 53 45 4c 45 43 54 20 74 69 64 2c 20 6e 61 SELECT tid, na
5270: 6d 65 20 46 52 4f 4d 20 63 73 74 79 70 65 3b 0a me FROM cstype;.
5280: 09 7d 5d 20 7b 20 73 65 74 20 6d 79 63 73 74 79 .}] { set mycsty
5290: 70 65 28 24 6e 61 6d 65 29 20 24 74 69 64 20 7d pe($name) $tid }
52a0: 0a 09 72 65 74 75 72 6e 0a 20 20 20 20 7d 0a 0a ..return. }..
52b0: 20 20 20 20 74 79 70 65 6d 65 74 68 6f 64 20 6c typemethod l
52c0: 6f 61 64 20 7b 72 65 70 6f 73 69 74 6f 72 79 7d oad {repository}
52d0: 20 7b 0a 09 73 65 74 20 6e 20 30 0a 09 6c 6f 67 {..set n 0..log
52e0: 20 77 72 69 74 65 20 32 20 63 73 65 74 73 20 7b write 2 csets {
52f0: 4c 6f 61 64 69 6e 67 20 74 68 65 20 63 68 61 6e Loading the chan
5300: 67 65 73 65 74 73 7d 0a 09 66 6f 72 65 61 63 68 gesets}..foreach
5310: 20 7b 69 64 20 70 69 64 20 63 73 74 79 70 65 20 {id pid cstype
5320: 73 72 63 69 64 7d 20 5b 73 74 61 74 65 20 72 75 srcid} [state ru
5330: 6e 20 7b 0a 09 20 20 20 20 53 45 4c 45 43 54 20 n {.. SELECT
5340: 43 2e 63 69 64 2c 20 43 2e 70 69 64 2c 20 43 53 C.cid, C.pid, CS
5350: 2e 6e 61 6d 65 2c 20 43 2e 73 72 63 0a 09 20 20 .name, C.src..
5360: 20 20 46 52 4f 4d 20 20 20 63 68 61 6e 67 65 73 FROM changes
5370: 65 74 20 43 2c 20 63 73 74 79 70 65 20 43 53 0a et C, cstype CS.
5380: 09 20 20 20 20 57 48 45 52 45 20 20 43 2e 74 79 . WHERE C.ty
5390: 70 65 20 3d 20 43 53 2e 74 69 64 0a 09 20 20 20 pe = CS.tid..
53a0: 20 4f 52 44 45 52 20 42 59 20 43 2e 63 69 64 0a ORDER BY C.cid.
53b0: 09 7d 5d 20 7b 0a 09 20 20 20 20 6c 6f 67 20 70 .}] {.. log p
53c0: 72 6f 67 72 65 73 73 20 32 20 63 73 65 74 73 20 rogress 2 csets
53d0: 24 6e 20 7b 7d 0a 09 20 20 20 20 73 65 74 20 72 $n {}.. set r
53e0: 20 5b 24 74 79 70 65 20 25 41 55 54 4f 25 20 5b [$type %AUTO% [
53f0: 24 72 65 70 6f 73 69 74 6f 72 79 20 70 72 6f 6a $repository proj
5400: 65 63 74 6f 66 20 24 70 69 64 5d 20 24 63 73 74 ectof $pid] $cst
5410: 79 70 65 20 24 73 72 63 69 64 20 5b 73 74 61 74 ype $srcid [stat
5420: 65 20 72 75 6e 20 7b 0a 09 09 53 45 4c 45 43 54 e run {...SELECT
5430: 20 43 2e 69 69 64 0a 09 09 46 52 4f 4d 20 20 20 C.iid...FROM
5440: 63 73 69 74 65 6d 20 43 0a 09 09 57 48 45 52 45 csitem C...WHERE
5450: 20 20 43 2e 63 69 64 20 3d 20 24 69 64 0a 09 09 C.cid = $id...
5460: 4f 52 44 45 52 20 42 59 20 43 2e 70 6f 73 0a 09 ORDER BY C.pos..
5470: 20 20 20 20 7d 5d 20 24 69 64 5d 0a 09 20 20 20 }] $id]..
5480: 20 69 6e 63 72 20 6e 0a 09 7d 0a 09 72 65 74 75 incr n..}..retu
5490: 72 6e 0a 20 20 20 20 7d 0a 0a 20 20 20 20 74 79 rn. }.. ty
54a0: 70 65 6d 65 74 68 6f 64 20 6c 6f 61 64 63 6f 75 pemethod loadcou
54b0: 6e 74 65 72 20 7b 7d 20 7b 0a 09 23 20 49 6e 69 nter {} {..# Ini
54c0: 74 69 61 6c 69 7a 65 20 74 68 65 20 63 6f 75 6e tialize the coun
54d0: 74 65 72 20 66 72 6f 6d 20 74 68 65 20 73 74 61 ter from the sta
54e0: 74 65 0a 09 6c 6f 67 20 77 72 69 74 65 20 32 20 te..log write 2
54f0: 63 73 65 74 73 20 7b 4c 6f 61 64 69 6e 67 20 63 csets {Loading c
5500: 68 61 6e 67 65 73 65 74 20 63 6f 75 6e 74 65 72 hangeset counter
5510: 7d 0a 09 73 65 74 20 6d 79 63 6f 75 6e 74 65 72 }..set mycounter
5520: 20 5b 73 74 61 74 65 20 6f 6e 65 20 7b 20 53 45 [state one { SE
5530: 4c 45 43 54 20 4d 41 58 28 63 69 64 29 20 46 52 LECT MAX(cid) FR
5540: 4f 4d 20 63 68 61 6e 67 65 73 65 74 20 7d 5d 0a OM changeset }].
5550: 09 72 65 74 75 72 6e 0a 20 20 20 20 7d 0a 0a 20 .return. }..
5560: 20 20 20 74 79 70 65 6d 65 74 68 6f 64 20 6e 75 typemethod nu
5570: 6d 20 7b 7d 20 7b 20 72 65 74 75 72 6e 20 24 6d m {} { return $m
5580: 79 63 6f 75 6e 74 65 72 20 7d 0a 0a 20 20 20 20 ycounter }..
5590: 70 72 6f 63 20 49 6e 69 74 69 61 6c 69 7a 65 42 proc InitializeB
55a0: 72 65 61 6b 53 74 61 74 65 20 7b 72 65 76 69 73 reakState {revis
55b0: 69 6f 6e 73 7d 20 7b 0a 09 75 70 76 61 72 20 31 ions} {..upvar 1
55c0: 20 70 6f 73 20 70 6f 73 20 63 72 6f 73 73 20 63 pos pos cross c
55d0: 72 6f 73 73 20 72 61 6e 67 65 20 72 61 6e 67 65 ross range range
55e0: 20 64 65 70 63 20 64 65 70 63 20 64 65 6c 74 61 depc depc delta
55f0: 20 64 65 6c 74 61 20 5c 0a 09 20 20 20 20 64 65 delta \.. de
5600: 70 65 6e 64 65 6e 63 69 65 73 20 64 65 70 65 6e pendencies depen
5610: 64 65 6e 63 69 65 73 0a 0a 09 23 20 46 69 72 73 dencies...# Firs
5620: 74 20 77 65 20 63 72 65 61 74 65 20 61 20 6d 61 t we create a ma
5630: 70 20 6f 66 20 70 6f 73 69 74 69 6f 6e 73 20 74 p of positions t
5640: 6f 20 6d 61 6b 65 20 69 74 20 65 61 73 69 65 72 o make it easier
5650: 20 74 6f 0a 09 23 20 64 65 74 65 72 6d 69 6e 65 to..# determine
5660: 20 77 68 65 74 68 65 72 20 61 20 64 65 70 65 6e whether a depen
5670: 64 65 6e 63 79 20 63 72 6f 73 73 65 73 20 61 20 dency crosses a
5680: 70 61 72 74 69 63 75 6c 61 72 20 69 6e 64 65 78 particular index
5690: 2e 0a 0a 09 61 72 72 61 79 20 73 65 74 20 70 6f ....array set po
56a0: 73 20 20 20 7b 7d 0a 09 61 72 72 61 79 20 73 65 s {}..array se
56b0: 74 20 63 72 6f 73 73 20 7b 7d 0a 09 61 72 72 61 t cross {}..arra
56c0: 79 20 73 65 74 20 64 65 70 63 20 20 7b 7d 0a 09 y set depc {}..
56d0: 73 65 74 20 72 61 6e 67 65 20 20 20 20 20 20 20 set range
56e0: 7b 7d 0a 09 73 65 74 20 6e 20 30 0a 09 66 6f 72 {}..set n 0..for
56f0: 65 61 63 68 20 72 65 76 20 24 72 65 76 69 73 69 each rev $revisi
5700: 6f 6e 73 20 7b 0a 09 20 20 20 20 6c 61 70 70 65 ons {.. lappe
5710: 6e 64 20 72 61 6e 67 65 20 24 6e 0a 09 20 20 20 nd range $n..
5720: 20 73 65 74 20 70 6f 73 28 24 72 65 76 29 20 24 set pos($rev) $
5730: 6e 0a 09 20 20 20 20 73 65 74 20 63 72 6f 73 73 n.. set cross
5740: 28 24 6e 29 20 30 0a 09 20 20 20 20 69 6e 63 72 ($n) 0.. incr
5750: 20 6e 0a 09 7d 0a 0a 09 23 20 53 65 63 6f 6e 64 n..}...# Second
5760: 6c 79 20 77 65 20 63 6f 75 6e 74 20 74 68 65 20 ly we count the
5770: 63 72 6f 73 73 69 6e 67 73 20 70 65 72 20 70 6f crossings per po
5780: 73 69 74 69 6f 6e 2c 20 62 79 20 69 74 65 72 61 sition, by itera
5790: 74 69 6e 67 0a 09 23 20 6f 76 65 72 20 74 68 65 ting..# over the
57a0: 20 72 65 63 6f 72 64 65 64 20 69 6e 74 65 72 6e recorded intern
57b0: 61 6c 20 64 65 70 65 6e 64 65 6e 63 69 65 73 2e al dependencies.
57c0: 0a 0a 09 23 20 4e 6f 74 65 3a 20 49 66 20 74 68 ...# Note: If th
57d0: 65 20 74 69 6d 65 73 74 61 6d 70 73 20 61 72 65 e timestamps are
57e0: 20 62 61 64 6c 79 20 6f 75 74 20 6f 66 20 6f 72 badly out of or
57f0: 64 65 72 20 69 74 20 69 73 0a 09 23 20 20 20 20 der it is..#
5800: 20 20 20 70 6f 73 73 69 62 6c 65 20 74 6f 20 68 possible to h
5810: 61 76 65 20 61 20 62 61 63 6b 77 61 72 64 20 73 ave a backward s
5820: 75 63 63 65 73 73 6f 72 20 64 65 70 65 6e 64 65 uccessor depende
5830: 6e 63 79 2c 0a 09 23 20 20 20 20 20 20 20 69 2e ncy,..# i.
5840: 65 2e 20 77 69 74 68 20 73 74 61 72 74 20 3e 20 e. with start >
5850: 65 6e 64 2e 20 57 65 20 6d 61 79 20 68 61 76 65 end. We may have
5860: 20 74 6f 20 73 77 61 70 20 74 68 65 20 69 6e 64 to swap the ind
5870: 69 63 65 73 0a 09 23 20 20 20 20 20 20 20 74 6f ices..# to
5880: 20 65 6e 73 75 72 65 20 74 68 61 74 20 74 68 65 ensure that the
5890: 20 66 6f 6c 6c 6f 77 69 6e 67 20 6c 6f 6f 70 20 following loop
58a0: 72 75 6e 73 20 63 6f 72 72 65 63 74 6c 79 2e 0a runs correctly..
58b0: 09 23 0a 09 23 20 4e 6f 74 65 20 32 3a 20 73 74 .#..# Note 2: st
58c0: 61 72 74 20 3d 3d 20 65 6e 64 20 69 73 20 6e 6f art == end is no
58d0: 74 20 70 6f 73 73 69 62 6c 65 2e 20 49 74 20 69 t possible. It i
58e0: 6e 64 69 63 61 74 65 73 20 61 0a 09 23 20 20 20 ndicates a..#
58f0: 20 20 20 20 20 20 73 65 6c 66 2d 64 65 70 65 6e self-depen
5900: 64 65 6e 63 79 20 64 75 65 20 74 6f 20 74 68 65 dency due to the
5910: 20 75 6e 69 71 75 65 6e 65 73 73 20 6f 66 20 70 uniqueness of p
5920: 6f 73 69 74 69 6f 6e 73 2c 0a 09 23 20 20 20 20 ositions,..#
5930: 20 20 20 20 20 61 6e 64 20 74 68 61 74 20 69 73 and that is
5940: 20 73 6f 6d 65 74 68 69 6e 67 20 77 65 20 68 61 something we ha
5950: 76 65 20 72 75 6c 65 64 20 6f 75 74 20 61 6c 72 ve ruled out alr
5960: 65 61 64 79 2c 20 73 65 65 0a 09 23 20 20 20 20 eady, see..#
5970: 20 20 20 20 20 27 72 65 76 20 69 6e 74 65 72 6e 'rev intern
5980: 61 6c 73 75 63 63 65 73 73 6f 72 73 27 2e 0a 0a alsuccessors'...
5990: 09 66 6f 72 65 61 63 68 20 7b 72 69 64 20 63 68 .foreach {rid ch
59a0: 69 6c 64 72 65 6e 7d 20 5b 61 72 72 61 79 20 67 ildren} [array g
59b0: 65 74 20 64 65 70 65 6e 64 65 6e 63 69 65 73 5d et dependencies]
59c0: 20 7b 0a 09 20 20 20 20 66 6f 72 65 61 63 68 20 {.. foreach
59d0: 63 68 69 6c 64 20 24 63 68 69 6c 64 72 65 6e 20 child $children
59e0: 7b 0a 09 09 73 65 74 20 64 6b 65 79 20 20 20 20 {...set dkey
59f0: 5b 6c 69 73 74 20 24 72 69 64 20 24 63 68 69 6c [list $rid $chil
5a00: 64 5d 0a 09 09 73 65 74 20 73 74 61 72 74 20 20 d]...set start
5a10: 20 24 70 6f 73 28 24 72 69 64 29 0a 09 09 73 65 $pos($rid)...se
5a20: 74 20 65 6e 64 20 20 20 20 20 24 70 6f 73 28 24 t end $pos($
5a30: 63 68 69 6c 64 29 0a 09 09 73 65 74 20 63 72 6f child)...set cro
5a40: 73 73 65 73 20 7b 7d 0a 0a 09 09 69 66 20 7b 24 sses {}....if {$
5a50: 73 74 61 72 74 20 3e 20 24 65 6e 64 7d 20 7b 0a start > $end} {.
5a60: 09 09 20 20 20 20 77 68 69 6c 65 20 7b 24 65 6e .. while {$en
5a70: 64 20 3c 20 24 73 74 61 72 74 7d 20 7b 0a 09 09 d < $start} {...
5a80: 09 6c 61 70 70 65 6e 64 20 63 72 6f 73 73 65 73 .lappend crosses
5a90: 20 24 65 6e 64 0a 09 09 09 69 6e 63 72 20 63 72 $end....incr cr
5aa0: 6f 73 73 28 24 65 6e 64 29 0a 09 09 09 69 6e 63 oss($end)....inc
5ab0: 72 20 65 6e 64 0a 09 09 20 20 20 20 7d 0a 09 09 r end... }...
5ac0: 7d 20 65 6c 73 65 20 7b 0a 09 09 20 20 20 20 77 } else {... w
5ad0: 68 69 6c 65 20 7b 24 73 74 61 72 74 20 3c 20 24 hile {$start < $
5ae0: 65 6e 64 7d 20 7b 0a 09 09 09 6c 61 70 70 65 6e end} {....lappen
5af0: 64 20 63 72 6f 73 73 65 73 20 24 73 74 61 72 74 d crosses $start
5b00: 0a 09 09 09 69 6e 63 72 20 63 72 6f 73 73 28 24 ....incr cross($
5b10: 73 74 61 72 74 29 0a 09 09 09 69 6e 63 72 20 73 start)....incr s
5b20: 74 61 72 74 0a 09 09 20 20 20 20 7d 0a 09 09 7d tart... }...}
5b30: 0a 09 09 73 65 74 20 64 65 70 63 28 24 64 6b 65 ...set depc($dke
5b40: 79 29 20 24 63 72 6f 73 73 65 73 0a 09 20 20 20 y) $crosses..
5b50: 20 7d 0a 09 7d 0a 0a 09 49 6e 69 74 69 61 6c 69 }..}...Initiali
5b60: 7a 65 44 65 6c 74 61 73 20 24 72 65 76 69 73 69 zeDeltas $revisi
5b70: 6f 6e 73 0a 09 72 65 74 75 72 6e 0a 20 20 20 20 ons..return.
5b80: 7d 0a 0a 20 20 20 20 70 72 6f 63 20 49 6e 69 74 }.. proc Init
5b90: 69 61 6c 69 7a 65 44 65 6c 74 61 73 20 7b 72 65 ializeDeltas {re
5ba0: 76 69 73 69 6f 6e 73 7d 20 7b 0a 09 75 70 76 61 visions} {..upva
5bb0: 72 20 31 20 64 65 6c 74 61 20 64 65 6c 74 61 0a r 1 delta delta.
5bc0: 0a 09 23 20 50 75 6c 6c 20 74 68 65 20 74 69 6d ..# Pull the tim
5bd0: 65 73 74 61 6d 70 73 20 66 6f 72 20 61 6c 6c 20 estamps for all
5be0: 72 65 76 69 73 69 6f 6e 73 20 69 6e 20 74 68 65 revisions in the
5bf0: 20 63 68 61 6e 67 65 73 65 74 73 20 61 6e 64 0a changesets and.
5c00: 09 23 20 63 6f 6d 70 75 74 65 20 74 68 65 69 72 .# compute their
5c10: 20 64 65 6c 74 61 73 20 66 6f 72 20 75 73 65 20 deltas for use
5c20: 62 79 20 74 68 65 20 62 72 65 61 6b 20 66 69 6e by the break fin
5c30: 64 65 72 2e 0a 0a 09 61 72 72 61 79 20 73 65 74 der....array set
5c40: 20 64 65 6c 74 61 20 7b 7d 0a 09 61 72 72 61 79 delta {}..array
5c50: 20 73 65 74 20 73 74 61 6d 70 20 7b 7d 0a 0a 09 set stamp {}...
5c60: 73 65 74 20 74 68 65 73 65 74 20 28 27 5b 6a 6f set theset ('[jo
5c70: 69 6e 20 24 72 65 76 69 73 69 6f 6e 73 20 7b 27 in $revisions {'
5c80: 2c 27 7d 5d 27 29 0a 09 66 6f 72 65 61 63 68 20 ,'}]')..foreach
5c90: 7b 72 69 64 20 74 69 6d 65 7d 20 5b 73 74 61 74 {rid time} [stat
5ca0: 65 20 72 75 6e 20 5b 73 75 62 73 74 20 2d 6e 6f e run [subst -no
5cb0: 63 6f 6d 6d 61 6e 64 73 20 2d 6e 6f 62 61 63 6b commands -noback
5cc0: 73 6c 61 73 68 65 73 20 7b 0a 09 20 20 20 20 53 slashes {.. S
5cd0: 45 4c 45 43 54 20 52 2e 72 69 64 2c 20 52 2e 64 ELECT R.rid, R.d
5ce0: 61 74 65 0a 09 20 20 20 20 46 52 4f 4d 20 72 65 ate.. FROM re
5cf0: 76 69 73 69 6f 6e 20 52 0a 09 20 20 20 20 57 48 vision R.. WH
5d00: 45 52 45 20 52 2e 72 69 64 20 49 4e 20 24 74 68 ERE R.rid IN $th
5d10: 65 73 65 74 0a 09 7d 5d 5d 20 7b 0a 09 20 20 20 eset..}]] {..
5d20: 20 73 65 74 20 73 74 61 6d 70 28 24 72 69 64 29 set stamp($rid)
5d30: 20 24 74 69 6d 65 0a 09 7d 0a 0a 09 73 65 74 20 $time..}...set
5d40: 6e 20 30 0a 09 66 6f 72 65 61 63 68 20 72 69 64 n 0..foreach rid
5d50: 20 5b 6c 72 61 6e 67 65 20 24 72 65 76 69 73 69 [lrange $revisi
5d60: 6f 6e 73 20 30 20 65 6e 64 2d 31 5d 20 72 6e 65 ons 0 end-1] rne
5d70: 78 74 20 5b 6c 72 61 6e 67 65 20 24 72 65 76 69 xt [lrange $revi
5d80: 73 69 6f 6e 73 20 31 20 65 6e 64 5d 20 7b 0a 09 sions 1 end] {..
5d90: 20 20 20 20 73 65 74 20 64 65 6c 74 61 28 24 6e set delta($n
5da0: 29 20 5b 65 78 70 72 20 7b 24 73 74 61 6d 70 28 ) [expr {$stamp(
5db0: 24 72 6e 65 78 74 29 20 2d 20 24 73 74 61 6d 70 $rnext) - $stamp
5dc0: 28 24 72 69 64 29 7d 5d 0a 09 20 20 20 20 69 6e ($rid)}].. in
5dd0: 63 72 20 6e 0a 09 7d 0a 09 72 65 74 75 72 6e 0a cr n..}..return.
5de0: 20 20 20 20 7d 0a 0a 20 20 20 20 70 72 6f 63 20 }.. proc
5df0: 46 69 6e 64 42 65 73 74 42 72 65 61 6b 20 7b 72 FindBestBreak {r
5e00: 61 6e 67 65 7d 20 7b 0a 09 75 70 76 61 72 20 31 ange} {..upvar 1
5e10: 20 63 72 6f 73 73 20 63 72 6f 73 73 20 64 65 6c cross cross del
5e20: 74 61 20 64 65 6c 74 61 0a 0a 09 23 20 44 65 74 ta delta...# Det
5e30: 65 72 6d 69 6e 65 20 74 68 65 20 62 65 73 74 20 ermine the best
5e40: 62 72 65 61 6b 20 6c 6f 63 61 74 69 6f 6e 20 69 break location i
5e50: 6e 20 74 68 65 20 67 69 76 65 6e 20 72 61 6e 67 n the given rang
5e60: 65 20 6f 66 0a 09 23 20 70 6f 73 69 74 69 6f 6e e of..# position
5e70: 73 2e 20 46 69 72 73 74 20 77 65 20 6c 6f 6f 6b s. First we look
5e80: 20 66 6f 72 20 74 68 65 20 6c 6f 63 61 74 69 6f for the locatio
5e90: 6e 73 20 77 69 74 68 20 74 68 65 20 6d 61 78 69 ns with the maxi
5ea0: 6d 61 6c 0a 09 23 20 6e 75 6d 62 65 72 20 6f 66 mal..# number of
5eb0: 20 63 72 6f 73 73 69 6e 67 73 2e 20 49 66 20 74 crossings. If t
5ec0: 68 65 72 65 20 61 72 65 20 73 65 76 65 72 61 6c here are several
5ed0: 20 77 65 20 6c 6f 6f 6b 20 66 6f 72 20 74 68 65 we look for the
5ee0: 0a 09 23 20 73 68 6f 72 74 65 73 74 20 74 69 6d ..# shortest tim
5ef0: 65 20 69 6e 74 65 72 76 61 6c 20 61 6d 6f 6e 67 e interval among
5f00: 20 74 68 65 6d 2e 20 49 66 20 77 65 20 73 74 69 them. If we sti
5f10: 6c 6c 20 68 61 76 65 20 6d 75 6c 74 69 70 6c 65 ll have multiple
5f20: 0a 09 23 20 70 6f 73 73 69 62 69 6c 69 74 69 65 ..# possibilitie
5f30: 73 20 61 66 74 65 72 20 74 68 61 74 20 77 65 20 s after that we
5f40: 73 65 6c 65 63 74 20 74 68 65 20 65 61 72 6c 69 select the earli
5f50: 65 73 74 20 6c 6f 63 61 74 69 6f 6e 0a 09 23 20 est location..#
5f60: 61 6d 6f 6e 67 20 74 68 65 73 65 2e 0a 0a 09 23 among these....#
5f70: 20 4e 6f 74 65 3a 20 49 66 20 74 68 65 20 6d 61 Note: If the ma
5f80: 78 69 6d 61 6c 20 6e 75 6d 62 65 72 20 6f 66 20 ximal number of
5f90: 63 72 6f 73 73 69 6e 67 73 20 69 73 20 30 20 74 crossings is 0 t
5fa0: 68 65 6e 20 74 68 65 20 72 61 6e 67 65 0a 09 23 hen the range..#
5fb0: 20 20 20 20 20 20 20 68 61 73 20 6e 6f 20 69 6e has no in
5fc0: 74 65 72 6e 61 6c 20 64 65 70 65 6e 64 65 6e 63 ternal dependenc
5fd0: 69 65 73 2c 20 61 6e 64 20 6e 6f 20 62 72 65 61 ies, and no brea
5fe0: 6b 20 6c 6f 63 61 74 69 6f 6e 20 61 74 0a 09 23 k location at..#
5ff0: 20 20 20 20 20 20 20 61 6c 6c 2e 20 54 68 69 73 all. This
6000: 20 70 6f 73 73 69 62 69 6c 69 74 79 20 69 73 20 possibility is
6010: 73 69 67 6e 61 6c 65 64 20 76 69 61 20 72 65 73 signaled via res
6020: 75 6c 74 20 2d 31 2e 0a 0a 09 23 20 4e 6f 74 65 ult -1....# Note
6030: 3a 20 41 20 72 61 6e 67 65 20 6f 66 20 6c 65 6e : A range of len
6040: 67 74 68 20 31 20 6f 72 20 6c 65 73 73 20 63 61 gth 1 or less ca
6050: 6e 6e 6f 74 20 68 61 76 65 20 69 6e 74 65 72 6e nnot have intern
6060: 61 6c 0a 09 23 20 20 20 20 20 20 20 64 65 70 65 al..# depe
6070: 6e 64 65 6e 63 69 65 73 2c 20 61 73 20 74 68 61 ndencies, as tha
6080: 74 20 6e 65 65 64 73 20 61 74 20 6c 65 61 73 74 t needs at least
6090: 20 74 77 6f 20 72 65 76 69 73 69 6f 6e 73 20 69 two revisions i
60a0: 6e 0a 09 23 20 20 20 20 20 20 20 74 68 65 20 72 n..# the r
60b0: 61 6e 67 65 2e 0a 0a 09 69 66 20 7b 5b 6c 6c 65 ange....if {[lle
60c0: 6e 67 74 68 20 24 72 61 6e 67 65 5d 20 3c 20 32 ngth $range] < 2
60d0: 7d 20 7b 20 72 65 74 75 72 6e 20 2d 31 20 7d 0a } { return -1 }.
60e0: 0a 09 73 65 74 20 6d 61 78 20 2d 31 0a 09 73 65 ..set max -1..se
60f0: 74 20 62 65 73 74 20 7b 7d 0a 0a 09 66 6f 72 65 t best {}...fore
6100: 61 63 68 20 6c 6f 63 61 74 69 6f 6e 20 24 72 61 ach location $ra
6110: 6e 67 65 20 7b 0a 09 20 20 20 20 73 65 74 20 63 nge {.. set c
6120: 72 6f 73 73 69 6e 67 73 20 24 63 72 6f 73 73 28 rossings $cross(
6130: 24 6c 6f 63 61 74 69 6f 6e 29 0a 09 20 20 20 20 $location)..
6140: 69 66 20 7b 24 63 72 6f 73 73 69 6e 67 73 20 3e if {$crossings >
6150: 20 24 6d 61 78 7d 20 7b 0a 09 09 73 65 74 20 6d $max} {...set m
6160: 61 78 20 20 24 63 72 6f 73 73 69 6e 67 73 0a 09 ax $crossings..
6170: 09 73 65 74 20 62 65 73 74 20 5b 6c 69 73 74 20 .set best [list
6180: 24 6c 6f 63 61 74 69 6f 6e 5d 0a 09 09 63 6f 6e $location]...con
6190: 74 69 6e 75 65 0a 09 20 20 20 20 7d 20 65 6c 73 tinue.. } els
61a0: 65 69 66 20 7b 24 63 72 6f 73 73 69 6e 67 73 20 eif {$crossings
61b0: 3d 3d 20 24 6d 61 78 7d 20 7b 0a 09 09 6c 61 70 == $max} {...lap
61c0: 70 65 6e 64 20 62 65 73 74 20 24 6c 6f 63 61 74 pend best $locat
61d0: 69 6f 6e 0a 09 20 20 20 20 7d 0a 09 7d 0a 0a 09 ion.. }..}...
61e0: 69 66 20 7b 24 6d 61 78 20 3d 3d 20 30 7d 20 20 if {$max == 0}
61f0: 20 20 20 20 20 20 20 20 20 20 7b 20 72 65 74 75 { retu
6200: 72 6e 20 2d 31 20 7d 0a 09 69 66 20 7b 5b 6c 6c rn -1 }..if {[ll
6210: 65 6e 67 74 68 20 24 62 65 73 74 5d 20 3d 3d 20 ength $best] ==
6220: 31 7d 20 7b 20 72 65 74 75 72 6e 20 5b 6c 69 6e 1} { return [lin
6230: 64 65 78 20 24 62 65 73 74 20 30 5d 20 7d 0a 0a dex $best 0] }..
6240: 09 73 65 74 20 6c 6f 63 61 74 69 6f 6e 73 20 24 .set locations $
6250: 62 65 73 74 0a 09 73 65 74 20 62 65 73 74 20 7b best..set best {
6260: 7d 0a 09 73 65 74 20 6d 69 6e 20 2d 31 0a 0a 09 }..set min -1...
6270: 66 6f 72 65 61 63 68 20 6c 6f 63 61 74 69 6f 6e foreach location
6280: 20 24 6c 6f 63 61 74 69 6f 6e 73 20 7b 0a 09 20 $locations {..
6290: 20 20 20 73 65 74 20 69 6e 74 65 72 76 61 6c 20 set interval
62a0: 24 64 65 6c 74 61 28 24 6c 6f 63 61 74 69 6f 6e $delta($location
62b0: 29 0a 09 20 20 20 20 69 66 20 7b 28 24 6d 69 6e ).. if {($min
62c0: 20 3c 20 30 29 20 7c 7c 20 28 24 69 6e 74 65 72 < 0) || ($inter
62d0: 76 61 6c 20 3c 20 24 6d 69 6e 29 7d 20 7b 0a 09 val < $min)} {..
62e0: 09 73 65 74 20 6d 69 6e 20 20 24 69 6e 74 65 72 .set min $inter
62f0: 76 61 6c 0a 09 09 73 65 74 20 62 65 73 74 20 5b val...set best [
6300: 6c 69 73 74 20 24 6c 6f 63 61 74 69 6f 6e 5d 0a list $location].
6310: 09 20 20 20 20 7d 20 65 6c 73 65 69 66 20 7b 24 . } elseif {$
6320: 69 6e 74 65 72 76 61 6c 20 3d 3d 20 24 6d 69 6e interval == $min
6330: 7d 20 7b 0a 09 09 6c 61 70 70 65 6e 64 20 62 65 } {...lappend be
6340: 73 74 20 24 6c 6f 63 61 74 69 6f 6e 0a 09 20 20 st $location..
6350: 20 20 7d 0a 09 7d 0a 0a 09 69 66 20 7b 5b 6c 6c }..}...if {[ll
6360: 65 6e 67 74 68 20 24 62 65 73 74 5d 20 3d 3d 20 ength $best] ==
6370: 31 7d 20 7b 20 72 65 74 75 72 6e 20 5b 6c 69 6e 1} { return [lin
6380: 64 65 78 20 24 62 65 73 74 20 30 5d 20 7d 0a 0a dex $best 0] }..
6390: 09 72 65 74 75 72 6e 20 5b 6c 69 6e 64 65 78 20 .return [lindex
63a0: 5b 6c 73 6f 72 74 20 2d 69 6e 74 65 67 65 72 20 [lsort -integer
63b0: 2d 69 6e 63 72 65 61 73 69 6e 67 20 24 62 65 73 -increasing $bes
63c0: 74 5d 20 30 5d 0a 20 20 20 20 7d 0a 0a 20 20 20 t] 0]. }..
63d0: 20 70 72 6f 63 20 43 75 74 41 74 20 7b 6c 6f 63 proc CutAt {loc
63e0: 61 74 69 6f 6e 7d 20 7b 0a 09 75 70 76 61 72 20 ation} {..upvar
63f0: 31 20 63 72 6f 73 73 20 63 72 6f 73 73 20 64 65 1 cross cross de
6400: 70 63 20 64 65 70 63 0a 0a 09 23 20 49 74 20 77 pc depc...# It w
6410: 61 73 20 64 65 63 69 64 65 64 20 74 6f 20 73 70 as decided to sp
6420: 6c 69 74 20 74 68 65 20 63 68 61 6e 67 65 73 65 lit the changese
6430: 74 20 61 74 20 74 68 65 20 67 69 76 65 6e 0a 09 t at the given..
6440: 23 20 6c 6f 63 61 74 69 6f 6e 2e 20 54 68 69 73 # location. This
6450: 20 63 75 74 73 20 61 20 6e 75 6d 62 65 72 20 6f cuts a number o
6460: 66 20 64 65 70 65 6e 64 65 6e 63 69 65 73 2e 20 f dependencies.
6470: 48 65 72 65 20 77 65 20 75 70 64 61 74 65 0a 09 Here we update..
6480: 23 20 74 68 65 20 63 72 6f 73 73 20 69 6e 66 6f # the cross info
6490: 72 6d 61 74 69 6f 6e 20 73 6f 20 74 68 61 74 20 rmation so that
64a0: 74 68 65 20 62 72 65 61 6b 20 66 69 6e 64 65 72 the break finder
64b0: 20 68 61 73 20 61 63 63 75 72 61 74 65 0a 09 23 has accurate..#
64c0: 20 64 61 74 61 20 77 68 65 6e 20 77 65 20 6c 6f data when we lo
64d0: 6f 6b 20 61 74 20 74 68 65 20 67 65 6e 65 72 61 ok at the genera
64e0: 74 65 64 20 66 72 61 67 6d 65 6e 74 73 2e 0a 0a ted fragments...
64f0: 09 73 65 74 20 73 69 78 20 5b 6c 6f 67 20 76 69 .set six [log vi
6500: 73 69 62 6c 65 3f 20 36 5d 0a 0a 09 66 6f 72 65 sible? 6]...fore
6510: 61 63 68 20 7b 64 65 70 20 72 61 6e 67 65 7d 20 ach {dep range}
6520: 5b 61 72 72 61 79 20 67 65 74 20 64 65 70 63 5d [array get depc]
6530: 20 7b 0a 09 20 20 20 20 23 20 43 68 65 63 6b 20 {.. # Check
6540: 61 6c 6c 20 64 65 70 65 6e 64 65 6e 63 69 65 73 all dependencies
6550: 20 73 74 69 6c 6c 20 6b 6e 6f 77 6e 2c 20 74 61 still known, ta
6560: 6b 65 20 74 68 65 69 72 20 72 61 6e 67 65 20 61 ke their range a
6570: 6e 64 0a 09 20 20 20 20 23 20 73 65 65 20 69 66 nd.. # see if
6580: 20 74 68 65 20 62 72 65 61 6b 20 6c 6f 63 61 74 the break locat
6590: 69 6f 6e 20 66 61 6c 6c 73 20 77 69 74 68 69 6e ion falls within
65a0: 2e 0a 0a 09 20 20 20 20 42 6f 72 64 65 72 20 24 .... Border $
65b0: 72 61 6e 67 65 20 73 20 65 0a 09 20 20 20 20 69 range s e.. i
65c0: 66 20 7b 24 6c 6f 63 61 74 69 6f 6e 20 3c 20 24 f {$location < $
65d0: 73 7d 20 63 6f 6e 74 69 6e 75 65 20 3b 20 23 20 s} continue ; #
65e0: 62 72 65 61 6b 20 62 65 66 6f 72 65 20 72 61 6e break before ran
65f0: 67 65 2c 20 69 67 6e 6f 72 65 0a 09 20 20 20 20 ge, ignore..
6600: 69 66 20 7b 24 6c 6f 63 61 74 69 6f 6e 20 3e 20 if {$location >
6610: 24 65 7d 20 63 6f 6e 74 69 6e 75 65 20 3b 20 23 $e} continue ; #
6620: 20 62 72 65 61 6b 20 61 66 74 65 72 20 72 61 6e break after ran
6630: 67 65 2c 20 69 67 6e 6f 72 65 2e 0a 0a 09 20 20 ge, ignore....
6640: 20 20 23 20 54 68 69 73 20 64 65 70 65 6e 64 65 # This depende
6650: 6e 63 79 20 63 72 6f 73 73 65 73 20 74 68 65 20 ncy crosses the
6660: 62 72 65 61 6b 20 6c 6f 63 61 74 69 6f 6e 2e 20 break location.
6670: 57 65 20 72 65 6d 6f 76 65 20 69 74 0a 09 20 20 We remove it..
6680: 20 20 23 20 66 72 6f 6d 20 74 68 65 20 63 72 6f # from the cro
6690: 73 73 69 6e 67 73 20 63 6f 75 6e 74 65 72 73 2c ssings counters,
66a0: 20 61 6e 64 20 74 68 65 6e 20 61 6c 73 6f 20 66 and then also f
66b0: 72 6f 6d 20 74 68 65 20 73 65 74 0a 09 20 20 20 rom the set..
66c0: 20 23 20 6f 66 20 6b 6e 6f 77 6e 20 64 65 70 65 # of known depe
66d0: 6e 64 65 6e 63 69 65 73 2c 20 61 73 20 77 65 20 ndencies, as we
66e0: 61 72 65 20 64 6f 6e 65 20 77 69 74 68 20 69 74 are done with it
66f0: 2e 0a 0a 09 20 20 20 20 66 6f 72 65 61 63 68 20 .... foreach
6700: 6c 6f 63 20 24 64 65 70 63 28 24 64 65 70 29 20 loc $depc($dep)
6710: 7b 20 69 6e 63 72 20 63 72 6f 73 73 28 24 6c 6f { incr cross($lo
6720: 63 29 20 2d 31 20 7d 0a 09 20 20 20 20 75 6e 73 c) -1 }.. uns
6730: 65 74 20 64 65 70 63 28 24 64 65 70 29 0a 0a 09 et depc($dep)...
6740: 20 20 20 20 69 66 20 7b 21 24 73 69 78 7d 20 63 if {!$six} c
6750: 6f 6e 74 69 6e 75 65 0a 0a 09 20 20 20 20 73 74 ontinue... st
6760: 72 75 63 74 3a 3a 6c 69 73 74 20 61 73 73 69 67 ruct::list assig
6770: 6e 20 24 64 65 70 20 70 61 72 65 6e 74 20 63 68 n $dep parent ch
6780: 69 6c 64 0a 09 20 20 20 20 6c 6f 67 20 77 72 69 ild.. log wri
6790: 74 65 20 35 20 63 73 65 74 73 20 22 42 72 6f 6b te 5 csets "Brok
67a0: 65 20 64 65 70 65 6e 64 65 6e 63 79 20 5b 50 44 e dependency [PD
67b0: 20 24 70 61 72 65 6e 74 5d 20 2d 2d 3e 20 5b 50 $parent] --> [P
67c0: 44 20 24 63 68 69 6c 64 5d 22 0a 09 7d 0a 0a 09 D $child]"..}...
67d0: 72 65 74 75 72 6e 0a 20 20 20 20 7d 0a 0a 20 20 return. }..
67e0: 20 20 23 20 50 72 69 6e 74 20 69 64 65 6e 74 69 # Print identi
67f0: 66 79 69 6e 67 20 64 61 74 61 20 66 6f 72 20 61 fying data for a
6800: 20 72 65 76 69 73 69 6f 6e 20 28 70 72 6f 6a 65 revision (proje
6810: 63 74 2c 20 66 69 6c 65 2c 20 64 6f 74 74 65 64 ct, file, dotted
6820: 20 72 65 76 0a 20 20 20 20 23 20 6e 75 6d 62 65 rev. # numbe
6830: 72 29 2c 20 66 6f 72 20 68 69 67 68 20 76 65 72 r), for high ver
6840: 62 6f 73 69 74 79 20 6c 6f 67 20 6f 75 74 70 75 bosity log outpu
6850: 74 2e 0a 20 20 20 20 23 20 54 4f 44 4f 3a 20 52 t.. # TODO: R
6860: 65 70 6c 61 63 65 20 77 69 74 68 20 63 61 6c 6c eplace with call
6870: 20 74 6f 20 69 74 65 6d 73 74 72 20 28 6c 69 73 to itemstr (lis
6880: 74 20 72 65 76 20 24 69 64 29 0a 0a 20 20 20 20 t rev $id)..
6890: 70 72 6f 63 20 50 44 20 7b 69 64 7d 20 7b 0a 09 proc PD {id} {..
68a0: 66 6f 72 65 61 63 68 20 7b 70 20 66 20 72 7d 20 foreach {p f r}
68b0: 5b 73 74 61 74 65 20 72 75 6e 20 7b 0a 09 09 53 [state run {...S
68c0: 45 4c 45 43 54 20 50 2e 6e 61 6d 65 20 2c 20 46 ELECT P.name , F
68d0: 2e 6e 61 6d 65 2c 20 52 2e 72 65 76 0a 09 09 46 .name, R.rev...F
68e0: 52 4f 4d 20 72 65 76 69 73 69 6f 6e 20 52 2c 20 ROM revision R,
68f0: 66 69 6c 65 20 46 2c 20 70 72 6f 6a 65 63 74 20 file F, project
6900: 50 0a 09 09 57 48 45 52 45 20 52 2e 72 69 64 20 P...WHERE R.rid
6910: 3d 20 24 69 64 20 20 20 20 2d 2d 20 46 69 6e 64 = $id -- Find
6920: 20 73 70 65 63 69 66 69 65 64 20 66 69 6c 65 20 specified file
6930: 72 65 76 69 73 69 6f 6e 0a 09 09 41 4e 44 20 20 revision...AND
6940: 20 46 2e 66 69 64 20 3d 20 52 2e 66 69 64 20 20 F.fid = R.fid
6950: 2d 2d 20 47 65 74 20 66 69 6c 65 20 6f 66 20 74 -- Get file of t
6960: 68 65 20 72 65 76 69 73 69 6f 6e 0a 09 09 41 4e he revision...AN
6970: 44 20 20 20 50 2e 70 69 64 20 3d 20 46 2e 70 69 D P.pid = F.pi
6980: 64 20 20 2d 2d 20 47 65 74 20 70 72 6f 6a 65 63 d -- Get projec
6990: 74 20 6f 66 20 74 68 65 20 66 69 6c 65 2e 0a 09 t of the file...
69a0: 7d 5d 20 62 72 65 61 6b 0a 09 72 65 74 75 72 6e }] break..return
69b0: 20 22 27 24 70 20 3a 20 24 66 2f 24 72 27 22 0a "'$p : $f/$r'".
69c0: 20 20 20 20 7d 0a 0a 20 20 20 20 23 20 50 72 69 }.. # Pri
69d0: 6e 74 69 6e 67 20 6f 6e 65 20 6f 72 20 6d 6f 72 nting one or mor
69e0: 65 20 72 61 6e 67 65 73 2c 20 66 6f 72 6d 61 74 e ranges, format
69f0: 74 65 64 2c 20 61 6e 64 20 6f 6e 6c 79 20 74 68 ted, and only th
6a00: 65 69 72 20 62 6f 72 64 65 72 20 74 6f 0a 20 20 eir border to.
6a10: 20 20 23 20 6b 65 65 70 20 74 68 65 20 73 74 72 # keep the str
6a20: 69 6e 67 73 20 73 68 6f 72 74 2e 0a 0a 20 20 20 ings short...
6a30: 20 70 72 6f 63 20 50 52 73 20 7b 72 61 6e 67 65 proc PRs {range
6a40: 73 7d 20 7b 0a 09 72 65 74 75 72 6e 20 5b 73 74 s} {..return [st
6a50: 72 75 63 74 3a 3a 6c 69 73 74 20 6d 61 70 20 24 ruct::list map $
6a60: 72 61 6e 67 65 73 20 5b 6d 79 70 72 6f 63 20 50 ranges [myproc P
6a70: 52 5d 5d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 70 R]]. }.. p
6a80: 72 6f 63 20 50 52 20 7b 72 61 6e 67 65 7d 20 7b roc PR {range} {
6a90: 0a 09 42 6f 72 64 65 72 20 24 72 61 6e 67 65 20 ..Border $range
6aa0: 73 20 65 0a 09 72 65 74 75 72 6e 20 3c 24 7b 73 s e..return <${s
6ab0: 7d 2e 2e 2e 24 7b 65 7d 3e 0a 20 20 20 20 7d 0a }...${e}>. }.
6ac0: 0a 20 20 20 20 70 72 6f 63 20 42 6f 72 64 65 72 . proc Border
6ad0: 20 7b 72 61 6e 67 65 20 73 76 20 65 76 7d 20 7b {range sv ev} {
6ae0: 0a 09 75 70 76 61 72 20 31 20 24 73 76 20 73 20 ..upvar 1 $sv s
6af0: 24 65 76 20 65 0a 09 73 65 74 20 73 20 5b 6c 69 $ev e..set s [li
6b00: 6e 64 65 78 20 24 72 61 6e 67 65 20 30 5d 0a 09 ndex $range 0]..
6b10: 73 65 74 20 65 20 5b 6c 69 6e 64 65 78 20 24 72 set e [lindex $r
6b20: 61 6e 67 65 20 65 6e 64 5d 0a 09 72 65 74 75 72 ange end]..retur
6b30: 6e 0a 20 20 20 20 7d 0a 0a 20 20 20 20 23 20 23 n. }.. # #
6b40: 20 23 23 20 23 23 23 20 23 23 23 23 23 20 23 23 ## ### ##### ##
6b50: 23 23 23 23 23 23 20 23 23 23 23 23 23 23 23 23 ###### #########
6b60: 23 23 23 23 0a 0a 20 20 20 20 74 79 70 65 76 61 ####.. typeva
6b70: 72 69 61 62 6c 65 20 6d 79 63 68 61 6e 67 65 73 riable mychanges
6b80: 65 74 73 20 20 20 20 20 20 20 20 20 7b 7d 20 3b ets {} ;
6b90: 20 23 20 4c 69 73 74 20 6f 66 20 61 6c 6c 20 6b # List of all k
6ba0: 6e 6f 77 6e 0a 09 09 09 09 09 20 20 20 23 20 63 nown...... # c
6bb0: 68 61 6e 67 65 73 65 74 73 2e 0a 20 20 20 20 74 hangesets.. t
6bc0: 79 70 65 76 61 72 69 61 62 6c 65 20 6d 79 74 63 ypevariable mytc
6bd0: 68 61 6e 67 65 73 65 74 73 20 2d 61 72 72 61 79 hangesets -array
6be0: 20 7b 7d 20 3b 20 23 20 4c 69 73 74 20 6f 66 20 {} ; # List of
6bf0: 61 6c 6c 20 6b 6e 6f 77 6e 0a 09 09 09 09 09 20 all known......
6c00: 20 20 23 20 63 68 61 6e 67 65 73 65 74 73 20 6f # changesets o
6c10: 66 20 61 20 74 79 70 65 2e 0a 20 20 20 20 74 79 f a type.. ty
6c20: 70 65 76 61 72 69 61 62 6c 65 20 6d 79 69 74 65 pevariable myite
6c30: 6d 6d 61 70 20 20 20 20 20 2d 61 72 72 61 79 20 mmap -array
6c40: 7b 7d 20 3b 20 23 20 4d 61 70 20 66 72 6f 6d 20 {} ; # Map from
6c50: 69 74 65 6d 73 20 28 74 61 67 67 65 64 29 0a 09 items (tagged)..
6c60: 09 09 09 09 20 20 20 23 20 74 6f 20 74 68 65 20 .... # to the
6c70: 6c 69 73 74 20 6f 66 20 63 68 61 6e 67 65 73 65 list of changese
6c80: 74 73 0a 09 09 09 09 09 20 20 20 23 20 63 6f 6e ts...... # con
6c90: 74 61 69 6e 69 6e 67 20 69 74 2e 20 45 61 63 68 taining it. Each
6ca0: 20 69 74 65 6d 0a 09 09 09 09 09 20 20 20 23 20 item...... #
6cb0: 63 61 6e 20 62 65 20 75 73 65 64 20 62 79 20 6f can be used by o
6cc0: 6e 6c 79 20 6f 6e 65 0a 09 09 09 09 09 20 20 20 nly one......
6cd0: 23 20 63 68 61 6e 67 65 73 65 74 2e 0a 20 20 20 # changeset..
6ce0: 20 74 79 70 65 76 61 72 69 61 62 6c 65 20 6d 79 typevariable my
6cf0: 69 64 6d 61 70 20 20 20 2d 61 72 72 61 79 20 7b idmap -array {
6d00: 7d 20 3b 20 23 20 4d 61 70 20 66 72 6f 6d 20 63 } ; # Map from c
6d10: 68 61 6e 67 65 73 65 74 20 69 64 20 74 6f 0a 09 hangeset id to..
6d20: 09 09 09 20 20 20 20 20 20 20 23 20 63 68 61 6e ... # chan
6d30: 67 65 73 65 74 2e 0a 0a 20 20 20 20 74 79 70 65 geset... type
6d40: 6d 65 74 68 6f 64 20 61 6c 6c 20 20 20 20 7b 7d method all {}
6d50: 20 20 20 20 7b 20 72 65 74 75 72 6e 20 24 6d 79 { return $my
6d60: 63 68 61 6e 67 65 73 65 74 73 20 7d 0a 20 20 20 changesets }.
6d70: 20 74 79 70 65 6d 65 74 68 6f 64 20 6f 66 20 20 typemethod of
6d80: 20 20 20 7b 63 69 64 7d 20 7b 20 72 65 74 75 72 {cid} { retur
6d90: 6e 20 24 6d 79 69 64 6d 61 70 28 24 63 69 64 29 n $myidmap($cid)
6da0: 20 7d 0a 20 20 20 20 74 79 70 65 6d 65 74 68 6f }. typemetho
6db0: 64 20 6f 66 69 74 65 6d 20 7b 69 69 64 7d 20 7b d ofitem {iid} {
6dc0: 20 72 65 74 75 72 6e 20 24 6d 79 69 74 65 6d 6d return $myitemm
6dd0: 61 70 28 24 69 69 64 29 20 7d 0a 0a 20 20 20 20 ap($iid) }..
6de0: 74 79 70 65 6d 65 74 68 6f 64 20 72 65 76 20 20 typemethod rev
6df0: 20 20 7b 7d 20 20 20 20 7b 20 72 65 74 75 72 6e {} { return
6e00: 20 24 6d 79 74 63 68 61 6e 67 65 73 65 74 73 28 $mytchangesets(
6e10: 72 65 76 29 20 7d 0a 20 20 20 20 74 79 70 65 6d rev) }. typem
6e20: 65 74 68 6f 64 20 73 79 6d 20 20 20 20 7b 7d 20 ethod sym {}
6e30: 20 20 20 7b 20 72 65 74 75 72 6e 20 5b 63 6f 6e { return [con
6e40: 63 61 74 20 5c 0a 09 09 09 09 09 20 20 24 7b 6d cat \...... ${m
6e50: 79 74 63 68 61 6e 67 65 73 65 74 73 28 73 79 6d ytchangesets(sym
6e60: 3a 3a 62 72 61 6e 63 68 29 7d 20 5c 0a 09 09 09 ::branch)} \....
6e70: 09 09 20 20 24 7b 6d 79 74 63 68 61 6e 67 65 73 .. ${mytchanges
6e80: 65 74 73 28 73 79 6d 3a 3a 74 61 67 29 7d 5d 20 ets(sym::tag)}]
6e90: 7d 0a 0a 20 20 20 20 23 20 23 20 23 23 20 23 23 }.. # # ## ##
6ea0: 23 20 23 23 23 23 23 20 23 23 23 23 23 23 23 23 # ##### ########
6eb0: 20 23 23 23 23 23 23 23 23 23 23 23 23 23 0a 20 #############.
6ec0: 20 20 20 23 23 20 43 6f 6e 66 69 67 75 72 61 74 ## Configurat
6ed0: 69 6f 6e 0a 0a 20 20 20 20 70 72 61 67 6d 61 20 ion.. pragma
6ee0: 2d 68 61 73 74 79 70 65 69 6e 66 6f 20 20 20 20 -hastypeinfo
6ef0: 6e 6f 20 20 3b 20 23 20 6e 6f 20 74 79 70 65 20 no ; # no type
6f00: 69 6e 74 72 6f 73 70 65 63 74 69 6f 6e 0a 20 20 introspection.
6f10: 20 20 70 72 61 67 6d 61 20 2d 68 61 73 69 6e 66 pragma -hasinf
6f20: 6f 20 20 20 20 20 20 20 20 6e 6f 20 20 3b 20 23 o no ; #
6f30: 20 6e 6f 20 6f 62 6a 65 63 74 20 69 6e 74 72 6f no object intro
6f40: 73 70 65 63 74 69 6f 6e 0a 0a 20 20 20 20 23 20 spection.. #
6f50: 23 20 23 23 20 23 23 23 20 23 23 23 23 23 20 23 # ## ### ##### #
6f60: 23 23 23 23 23 23 23 20 23 23 23 23 23 23 23 23 ####### ########
6f70: 23 23 23 23 23 0a 7d 0a 0a 23 23 0a 23 23 20 4e #####.}..##.## N
6f80: 4f 54 45 3a 20 54 68 65 20 73 75 63 63 65 73 73 OTE: The success
6f90: 6f 72 20 61 6e 64 20 70 72 65 64 65 63 65 73 73 or and predecess
6fa0: 6f 72 20 6d 65 74 68 6f 64 73 20 64 65 66 69 6e or methods defin
6fb0: 65 64 20 62 79 20 74 68 65 20 63 6c 61 73 73 65 ed by the classe
6fc0: 73 0a 23 23 20 20 20 20 20 20 20 62 65 6c 6f 77 s.## below
6fd0: 20 61 72 65 20 2d 2d 20 62 6f 74 74 6c 65 20 6e are -- bottle n
6fe0: 65 63 6b 73 20 2d 2d 2e 20 4c 6f 6f 6b 20 66 6f ecks --. Look fo
6ff0: 72 20 77 61 79 73 20 74 6f 20 6d 61 6b 65 20 74 r ways to make t
7000: 68 65 20 53 51 4c 0a 23 23 20 20 20 20 20 20 20 he SQL.##
7010: 66 61 73 74 65 72 2e 0a 23 23 0a 0a 23 20 23 20 faster..##..# #
7020: 23 23 20 23 23 23 20 23 23 23 23 23 20 23 23 23 ## ### ##### ###
7030: 23 23 23 23 23 20 23 23 23 23 23 23 23 23 23 23 ##### ##########
7040: 23 23 23 20 23 23 23 23 23 23 23 23 23 23 23 23 ### ############
7050: 23 23 23 23 23 23 23 23 23 0a 23 23 20 48 65 6c #########.## Hel
7060: 70 65 72 20 73 69 6e 67 6c 65 74 6f 6e 2e 20 43 per singleton. C
7070: 6f 6d 6d 61 6e 64 73 20 66 6f 72 20 72 65 76 69 ommands for revi
7080: 73 69 6f 6e 20 63 68 61 6e 67 65 73 65 74 73 2e sion changesets.
7090: 0a 0a 73 6e 69 74 3a 3a 74 79 70 65 20 3a 3a 76 ..snit::type ::v
70a0: 63 3a 3a 66 6f 73 73 69 6c 3a 3a 69 6d 70 6f 72 c::fossil::impor
70b0: 74 3a 3a 63 76 73 3a 3a 70 72 6f 6a 65 63 74 3a t::cvs::project:
70c0: 3a 72 65 76 3a 3a 72 65 76 20 7b 0a 20 20 20 20 :rev::rev {.
70d0: 74 79 70 65 6d 65 74 68 6f 64 20 62 79 72 65 76 typemethod byrev
70e0: 69 73 69 6f 6e 20 7b 7d 20 7b 20 72 65 74 75 72 ision {} { retur
70f0: 6e 20 31 20 7d 0a 20 20 20 20 74 79 70 65 6d 65 n 1 }. typeme
7100: 74 68 6f 64 20 62 79 73 79 6d 62 6f 6c 20 20 20 thod bysymbol
7110: 7b 7d 20 7b 20 72 65 74 75 72 6e 20 30 20 7d 0a {} { return 0 }.
7120: 20 20 20 20 74 79 70 65 6d 65 74 68 6f 64 20 69 typemethod i
7130: 73 74 61 67 20 20 20 20 20 20 7b 7d 20 7b 20 72 stag {} { r
7140: 65 74 75 72 6e 20 30 20 7d 0a 20 20 20 20 74 79 eturn 0 }. ty
7150: 70 65 6d 65 74 68 6f 64 20 69 73 62 72 61 6e 63 pemethod isbranc
7160: 68 20 20 20 7b 7d 20 7b 20 72 65 74 75 72 6e 20 h {} { return
7170: 30 20 7d 0a 0a 20 20 20 20 74 79 70 65 6d 65 74 0 }.. typemet
7180: 68 6f 64 20 73 74 72 20 7b 72 65 76 69 73 69 6f hod str {revisio
7190: 6e 7d 20 7b 0a 09 73 74 72 75 63 74 3a 3a 6c 69 n} {..struct::li
71a0: 73 74 20 61 73 73 69 67 6e 20 5b 73 74 61 74 65 st assign [state
71b0: 20 72 75 6e 20 7b 0a 09 20 20 20 20 53 45 4c 45 run {.. SELE
71c0: 43 54 20 52 2e 72 65 76 2c 20 46 2e 6e 61 6d 65 CT R.rev, F.name
71d0: 2c 20 50 2e 6e 61 6d 65 0a 09 20 20 20 20 46 52 , P.name.. FR
71e0: 4f 4d 20 20 20 72 65 76 69 73 69 6f 6e 20 52 2c OM revision R,
71f0: 20 66 69 6c 65 20 46 2c 20 70 72 6f 6a 65 63 74 file F, project
7200: 20 50 0a 09 20 20 20 20 57 48 45 52 45 20 20 52 P.. WHERE R
7210: 2e 72 69 64 20 3d 20 24 72 65 76 69 73 69 6f 6e .rid = $revision
7220: 20 2d 2d 20 46 69 6e 64 20 73 70 65 63 69 66 69 -- Find specifi
7230: 65 64 20 66 69 6c 65 20 72 65 76 69 73 69 6f 6e ed file revision
7240: 0a 09 20 20 20 20 41 4e 44 20 20 20 20 46 2e 66 .. AND F.f
7250: 69 64 20 3d 20 52 2e 66 69 64 20 20 20 20 20 2d id = R.fid -
7260: 2d 20 47 65 74 20 66 69 6c 65 20 6f 66 20 74 68 - Get file of th
7270: 65 20 72 65 76 69 73 69 6f 6e 0a 09 20 20 20 20 e revision..
7280: 41 4e 44 20 20 20 20 50 2e 70 69 64 20 3d 20 46 AND P.pid = F
7290: 2e 70 69 64 20 20 20 20 20 2d 2d 20 47 65 74 20 .pid -- Get
72a0: 70 72 6f 6a 65 63 74 20 6f 66 20 74 68 65 20 66 project of the f
72b0: 69 6c 65 2e 0a 09 7d 5d 20 72 65 76 6e 72 20 66 ile...}] revnr f
72c0: 6e 61 6d 65 20 70 6e 61 6d 65 0a 09 72 65 74 75 name pname..retu
72d0: 72 6e 20 22 24 70 6e 61 6d 65 2f 24 7b 72 65 76 rn "$pname/${rev
72e0: 6e 72 7d 3a 3a 24 66 6e 61 6d 65 22 0a 20 20 20 nr}::$fname".
72f0: 20 7d 0a 0a 20 20 20 20 23 20 72 65 73 75 6c 74 }.. # result
7300: 20 3d 20 6c 69 73 74 20 28 6d 69 6e 74 69 6d 65 = list (mintime
7310: 2c 20 6d 61 78 74 69 6d 65 29 0a 20 20 20 20 74 , maxtime). t
7320: 79 70 65 6d 65 74 68 6f 64 20 74 69 6d 65 72 61 ypemethod timera
7330: 6e 67 65 20 7b 69 74 65 6d 73 7d 20 7b 0a 09 73 nge {items} {..s
7340: 65 74 20 74 68 65 73 65 74 20 28 27 5b 6a 6f 69 et theset ('[joi
7350: 6e 20 24 69 74 65 6d 73 20 7b 27 2c 27 7d 5d 27 n $items {','}]'
7360: 29 0a 09 72 65 74 75 72 6e 20 5b 73 74 61 74 65 )..return [state
7370: 20 72 75 6e 20 5b 73 75 62 73 74 20 2d 6e 6f 63 run [subst -noc
7380: 6f 6d 6d 61 6e 64 73 20 2d 6e 6f 62 61 63 6b 73 ommands -nobacks
7390: 6c 61 73 68 65 73 20 7b 0a 09 20 20 20 20 53 45 lashes {.. SE
73a0: 4c 45 43 54 20 4d 49 4e 28 52 2e 64 61 74 65 29 LECT MIN(R.date)
73b0: 2c 20 4d 41 58 28 52 2e 64 61 74 65 29 0a 09 20 , MAX(R.date)..
73c0: 20 20 20 46 52 4f 4d 20 72 65 76 69 73 69 6f 6e FROM revision
73d0: 20 52 0a 09 20 20 20 20 57 48 45 52 45 20 52 2e R.. WHERE R.
73e0: 72 69 64 20 49 4e 20 24 74 68 65 73 65 74 20 2d rid IN $theset -
73f0: 2d 20 52 65 73 74 72 69 63 74 20 74 6f 20 72 65 - Restrict to re
7400: 76 69 73 69 6f 6e 73 20 6f 66 20 69 6e 74 65 72 visions of inter
7410: 65 73 74 0a 09 7d 5d 5d 0a 20 20 20 20 7d 0a 0a est..}]]. }..
7420: 20 20 20 20 23 20 76 61 72 28 64 76 29 20 3d 20 # var(dv) =
7430: 64 69 63 74 20 28 72 65 76 69 73 69 6f 6e 20 2d dict (revision -
7440: 3e 20 6c 69 73 74 20 28 72 65 76 69 73 69 6f 6e > list (revision
7450: 29 29 0a 20 20 20 20 74 79 70 65 6d 65 74 68 6f )). typemetho
7460: 64 20 69 6e 74 65 72 6e 61 6c 73 75 63 63 65 73 d internalsucces
7470: 73 6f 72 73 20 7b 64 76 20 72 65 76 69 73 69 6f sors {dv revisio
7480: 6e 73 7d 20 7b 0a 09 75 70 76 61 72 20 31 20 24 ns} {..upvar 1 $
7490: 64 76 20 64 65 70 65 6e 64 65 6e 63 69 65 73 0a dv dependencies.
74a0: 09 73 65 74 20 74 68 65 73 65 74 20 28 27 5b 6a .set theset ('[j
74b0: 6f 69 6e 20 24 72 65 76 69 73 69 6f 6e 73 20 7b oin $revisions {
74c0: 27 2c 27 7d 5d 27 29 0a 0a 09 23 20 53 65 65 20 ','}]')...# See
74d0: 27 73 75 63 63 65 73 73 6f 72 73 27 20 62 65 6c 'successors' bel
74e0: 6f 77 20 66 6f 72 20 74 68 65 20 6d 61 69 6e 20 ow for the main
74f0: 65 78 70 6c 61 6e 61 74 69 6f 6e 20 6f 66 0a 09 explanation of..
7500: 23 20 74 68 65 20 76 61 72 69 6f 75 73 20 63 61 # the various ca
7510: 73 65 73 2e 20 54 68 69 73 20 70 69 65 63 65 20 ses. This piece
7520: 69 73 20 73 70 65 63 69 61 6c 20 69 6e 20 74 68 is special in th
7530: 61 74 20 69 74 0a 09 23 20 72 65 73 74 72 69 63 at it..# restric
7540: 74 73 20 74 68 65 20 73 75 63 63 65 73 73 6f 72 ts the successor
7550: 73 20 77 65 20 6c 6f 6f 6b 20 66 6f 72 20 74 6f s we look for to
7560: 20 74 68 65 20 73 61 6d 65 20 73 65 74 20 6f 66 the same set of
7570: 0a 09 23 20 72 65 76 69 73 69 6f 6e 73 20 77 65 ..# revisions we
7580: 20 73 74 61 72 74 20 66 72 6f 6d 2e 20 53 65 6e start from. Sen
7590: 73 69 62 6c 65 20 61 73 20 77 65 20 61 72 65 20 sible as we are
75a0: 6c 6f 6f 6b 69 6e 67 20 66 6f 72 0a 09 23 20 63 looking for..# c
75b0: 68 61 6e 67 65 73 65 74 20 69 6e 74 65 72 6e 61 hangeset interna
75c0: 6c 20 64 65 70 65 6e 64 65 6e 63 69 65 73 2e 0a l dependencies..
75d0: 0a 09 61 72 72 61 79 20 73 65 74 20 64 65 70 20 ..array set dep
75e0: 7b 7d 0a 0a 09 66 6f 72 65 61 63 68 20 7b 72 69 {}...foreach {ri
75f0: 64 20 63 68 69 6c 64 7d 20 5b 73 74 61 74 65 20 d child} [state
7600: 72 75 6e 20 5b 73 75 62 73 74 20 2d 6e 6f 63 6f run [subst -noco
7610: 6d 6d 61 6e 64 73 20 2d 6e 6f 62 61 63 6b 73 6c mmands -nobacksl
7620: 61 73 68 65 73 20 7b 0a 20 20 20 20 2d 2d 20 28 ashes {. -- (
7630: 31 29 20 50 72 69 6d 61 72 79 20 63 68 69 6c 64 1) Primary child
7640: 0a 09 20 20 20 20 53 45 4c 45 43 54 20 52 2e 72 .. SELECT R.r
7650: 69 64 2c 20 52 2e 63 68 69 6c 64 0a 09 20 20 20 id, R.child..
7660: 20 46 52 4f 4d 20 20 20 72 65 76 69 73 69 6f 6e FROM revision
7670: 20 52 0a 09 20 20 20 20 57 48 45 52 45 20 20 52 R.. WHERE R
7680: 2e 72 69 64 20 20 20 49 4e 20 24 74 68 65 73 65 .rid IN $these
7690: 74 20 20 20 20 20 2d 2d 20 52 65 73 74 72 69 63 t -- Restric
76a0: 74 20 74 6f 20 72 65 76 69 73 69 6f 6e 73 20 6f t to revisions o
76b0: 66 20 69 6e 74 65 72 65 73 74 0a 09 20 20 20 20 f interest..
76c0: 41 4e 44 20 20 20 20 52 2e 63 68 69 6c 64 20 49 AND R.child I
76d0: 53 20 4e 4f 54 20 4e 55 4c 4c 20 20 20 20 2d 2d S NOT NULL --
76e0: 20 48 61 73 20 70 72 69 6d 61 72 79 20 63 68 69 Has primary chi
76f0: 6c 64 0a 09 20 20 20 20 41 4e 44 20 20 20 20 52 ld.. AND R
7700: 2e 63 68 69 6c 64 20 49 4e 20 24 74 68 65 73 65 .child IN $these
7710: 74 20 20 20 20 20 2d 2d 20 57 68 69 63 68 20 69 t -- Which i
7720: 73 20 61 6c 73 6f 20 6f 66 20 69 6e 74 65 72 65 s also of intere
7730: 73 74 0a 20 20 20 20 55 4e 49 4f 4e 0a 20 20 20 st. UNION.
7740: 20 2d 2d 20 28 32 29 20 53 65 63 6f 6e 64 61 72 -- (2) Secondar
7750: 79 20 28 62 72 61 6e 63 68 29 20 63 68 69 6c 64 y (branch) child
7760: 72 65 6e 0a 09 20 20 20 20 53 45 4c 45 43 54 20 ren.. SELECT
7770: 52 2e 72 69 64 2c 20 42 2e 62 72 69 64 0a 09 20 R.rid, B.brid..
7780: 20 20 20 46 52 4f 4d 20 20 20 72 65 76 69 73 69 FROM revisi
7790: 6f 6e 20 52 2c 20 72 65 76 69 73 69 6f 6e 62 72 on R, revisionbr
77a0: 61 6e 63 68 63 68 69 6c 64 72 65 6e 20 42 0a 09 anchchildren B..
77b0: 20 20 20 20 57 48 45 52 45 20 20 52 2e 72 69 64 WHERE R.rid
77c0: 20 20 20 49 4e 20 24 74 68 65 73 65 74 20 20 20 IN $theset
77d0: 20 20 2d 2d 20 52 65 73 74 72 69 63 74 20 74 6f -- Restrict to
77e0: 20 72 65 76 69 73 69 6f 6e 73 20 6f 66 20 69 6e revisions of in
77f0: 74 65 72 65 73 74 0a 09 20 20 20 20 41 4e 44 20 terest.. AND
7800: 20 20 20 52 2e 72 69 64 20 3d 20 42 2e 72 69 64 R.rid = B.rid
7810: 20 20 20 20 20 20 20 20 20 20 2d 2d 20 53 65 6c -- Sel
7820: 65 63 74 20 73 75 62 73 65 74 20 6f 66 20 62 72 ect subset of br
7830: 61 6e 63 68 20 63 68 69 6c 64 72 65 6e 0a 09 20 anch children..
7840: 20 20 20 41 4e 44 20 20 20 20 42 2e 62 72 69 64 AND B.brid
7850: 20 49 4e 20 24 74 68 65 73 65 74 20 20 20 20 20 IN $theset
7860: 20 2d 2d 20 57 68 69 63 68 20 69 73 20 61 6c 73 -- Which is als
7870: 6f 20 6f 66 20 69 6e 74 65 72 65 73 74 0a 20 20 o of interest.
7880: 20 20 55 4e 49 4f 4e 0a 20 20 20 20 2d 2d 20 28 UNION. -- (
7890: 34 29 20 43 68 69 6c 64 20 6f 66 20 74 72 75 6e 4) Child of trun
78a0: 6b 20 72 6f 6f 74 20 73 75 63 63 65 73 73 6f 72 k root successor
78b0: 20 6f 66 20 6c 61 73 74 20 4e 54 44 42 20 6f 6e of last NTDB on
78c0: 20 74 72 75 6e 6b 2e 0a 09 20 20 20 20 53 45 4c trunk... SEL
78d0: 45 43 54 20 52 2e 72 69 64 2c 20 52 41 2e 63 68 ECT R.rid, RA.ch
78e0: 69 6c 64 0a 09 20 20 20 20 46 52 4f 4d 20 72 65 ild.. FROM re
78f0: 76 69 73 69 6f 6e 20 52 2c 20 72 65 76 69 73 69 vision R, revisi
7900: 6f 6e 20 52 41 0a 09 20 20 20 20 57 48 45 52 45 on RA.. WHERE
7910: 20 52 2e 72 69 64 20 20 20 49 4e 20 24 74 68 65 R.rid IN $the
7920: 73 65 74 20 20 20 20 20 20 2d 2d 20 52 65 73 74 set -- Rest
7930: 72 69 63 74 20 74 6f 20 72 65 76 69 73 69 6f 6e rict to revision
7940: 73 20 6f 66 20 69 6e 74 65 72 65 73 74 0a 09 20 s of interest..
7950: 20 20 20 41 4e 44 20 20 20 52 2e 69 73 64 65 66 AND R.isdef
7960: 61 75 6c 74 20 20 20 20 20 20 20 20 20 20 20 20 ault
7970: 20 2d 2d 20 52 65 73 74 72 69 63 74 20 74 6f 20 -- Restrict to
7980: 4e 54 44 42 0a 09 20 20 20 20 41 4e 44 20 20 20 NTDB.. AND
7990: 52 2e 64 62 63 68 69 6c 64 20 49 53 20 4e 4f 54 R.dbchild IS NOT
79a0: 20 4e 55 4c 4c 20 20 20 2d 2d 20 61 6e 64 20 6c NULL -- and l
79b0: 61 73 74 20 4e 54 44 42 20 62 65 6c 6f 6e 67 69 ast NTDB belongi
79c0: 6e 67 20 74 6f 20 74 72 75 6e 6b 0a 09 20 20 20 ng to trunk..
79d0: 20 41 4e 44 20 20 20 52 41 2e 72 69 64 20 3d 20 AND RA.rid =
79e0: 52 2e 64 62 63 68 69 6c 64 20 20 20 20 20 20 2d R.dbchild -
79f0: 2d 20 47 6f 20 64 69 72 65 63 74 6c 79 20 74 6f - Go directly to
7a00: 20 74 72 75 6e 6b 20 72 6f 6f 74 0a 09 20 20 20 trunk root..
7a10: 20 41 4e 44 20 20 20 52 41 2e 63 68 69 6c 64 20 AND RA.child
7a20: 49 53 20 4e 4f 54 20 4e 55 4c 4c 20 20 20 20 2d IS NOT NULL -
7a30: 2d 20 48 61 73 20 70 72 69 6d 61 72 79 20 63 68 - Has primary ch
7a40: 69 6c 64 2e 0a 20 20 20 20 20 20 20 20 20 20 20 ild..
7a50: 20 41 4e 44 20 20 20 52 41 2e 63 68 69 6c 64 20 AND RA.child
7a60: 49 4e 20 24 74 68 65 73 65 74 20 20 20 20 20 2d IN $theset -
7a70: 2d 20 57 68 69 63 68 20 69 73 20 61 6c 73 6f 20 - Which is also
7a80: 6f 66 20 69 6e 74 65 72 65 73 74 0a 09 7d 5d 5d of interest..}]]
7a90: 20 7b 0a 09 20 20 20 20 23 20 43 6f 6e 73 69 64 {.. # Consid
7aa0: 65 72 20 6d 6f 76 69 6e 67 20 74 68 69 73 20 74 er moving this t
7ab0: 6f 20 74 68 65 20 69 6e 74 65 67 72 69 74 79 20 o the integrity
7ac0: 6d 6f 64 75 6c 65 2e 0a 09 20 20 20 20 69 6e 74 module... int
7ad0: 65 67 72 69 74 79 20 61 73 73 65 72 74 20 7b 24 egrity assert {$
7ae0: 72 69 64 20 21 3d 20 24 63 68 69 6c 64 7d 20 7b rid != $child} {
7af0: 52 65 76 69 73 69 6f 6e 20 24 72 69 64 20 64 65 Revision $rid de
7b00: 70 65 6e 64 73 20 6f 6e 20 69 74 73 65 6c 66 2e pends on itself.
7b10: 7d 0a 09 20 20 20 20 6c 61 70 70 65 6e 64 20 64 }.. lappend d
7b20: 65 70 65 6e 64 65 6e 63 69 65 73 28 24 72 69 64 ependencies($rid
7b30: 29 20 24 63 68 69 6c 64 0a 09 20 20 20 20 73 65 ) $child.. se
7b40: 74 20 64 65 70 28 24 72 69 64 2c 24 63 68 69 6c t dep($rid,$chil
7b50: 64 29 20 2e 0a 09 7d 0a 0a 09 23 20 54 68 65 20 d) ...}...# The
7b60: 73 71 6c 20 73 74 61 74 65 6d 65 6e 74 73 20 61 sql statements a
7b70: 62 6f 76 65 20 6c 6f 6f 6b 73 20 6f 6e 6c 79 20 bove looks only
7b80: 66 6f 72 20 64 69 72 65 63 74 20 64 65 70 65 6e for direct depen
7b90: 64 65 6e 63 69 65 73 0a 09 23 20 62 65 74 77 65 dencies..# betwe
7ba0: 65 6e 20 72 65 76 69 73 69 6f 6e 20 69 6e 20 74 en revision in t
7bb0: 68 65 20 63 68 61 6e 67 65 73 65 74 2e 20 48 6f he changeset. Ho
7bc0: 77 65 76 65 72 20 64 75 65 20 74 6f 20 74 68 65 wever due to the
7bd0: 0a 09 23 20 76 61 67 61 72 69 65 73 20 6f 66 20 ..# vagaries of
7be0: 6d 65 74 61 20 64 61 74 61 20 69 74 20 69 73 20 meta data it is
7bf0: 70 6f 73 73 69 62 6c 65 20 66 6f 72 20 74 77 6f possible for two
7c00: 20 72 65 76 69 73 69 6f 6e 73 20 6f 66 0a 09 23 revisions of..#
7c10: 20 74 68 65 20 73 61 6d 65 20 66 69 6c 65 20 74 the same file t
7c20: 6f 20 65 6e 64 20 75 70 20 69 6e 20 74 68 65 20 o end up in the
7c30: 73 61 6d 65 20 63 68 61 6e 67 65 73 65 74 2c 20 same changeset,
7c40: 77 69 74 68 6f 75 74 20 61 0a 09 23 20 64 69 72 without a..# dir
7c50: 65 63 74 20 64 65 70 65 6e 64 65 6e 63 79 20 62 ect dependency b
7c60: 65 74 77 65 65 6e 20 74 68 65 6d 2e 20 48 6f 77 etween them. How
7c70: 65 76 65 72 20 77 65 20 6b 6e 6f 77 20 74 68 61 ever we know tha
7c80: 74 20 74 68 65 72 65 0a 09 23 20 68 61 73 20 74 t there..# has t
7c90: 6f 20 62 65 20 61 20 61 6e 20 69 6e 64 69 72 65 o be a an indire
7ca0: 63 74 20 64 65 70 65 6e 64 65 6e 63 79 2c 20 62 ct dependency, b
7cb0: 65 20 69 74 20 74 68 72 6f 75 67 68 20 70 72 69 e it through pri
7cc0: 6d 61 72 79 0a 09 23 20 63 68 69 6c 64 72 65 6e mary..# children
7cd0: 2c 20 62 72 61 6e 63 68 20 63 68 69 6c 64 72 65 , branch childre
7ce0: 6e 2c 20 6f 72 20 61 20 63 6f 6d 62 69 6e 61 74 n, or a combinat
7cf0: 69 6f 6e 20 74 68 65 72 65 6f 66 2e 0a 0a 09 23 ion thereof....#
7d00: 20 57 65 20 6e 6f 77 20 66 69 6c 6c 20 69 6e 20 We now fill in
7d10: 74 68 65 73 65 20 70 73 65 75 64 6f 2d 64 65 70 these pseudo-dep
7d20: 65 6e 64 65 6e 63 69 65 73 2c 20 69 66 20 6e 6f endencies, if no
7d30: 20 73 75 63 68 0a 09 23 20 64 65 70 65 6e 64 65 such..# depende
7d40: 6e 63 79 20 65 78 69 73 74 73 20 61 6c 72 65 61 ncy exists alrea
7d50: 64 79 2e 20 54 68 65 20 64 69 72 65 63 74 69 6f dy. The directio
7d60: 6e 20 6f 66 20 74 68 65 20 64 65 70 65 6e 64 65 n of the depende
7d70: 6e 63 79 0a 09 23 20 69 73 20 61 63 74 75 61 6c ncy..# is actual
7d80: 6c 79 20 69 72 72 65 6c 65 76 61 6e 74 20 66 6f ly irrelevant fo
7d90: 72 20 74 68 69 73 2e 0a 0a 09 23 20 4e 4f 54 45 r this....# NOTE
7da0: 3a 20 54 68 69 73 20 69 73 20 64 69 66 66 65 72 : This is differ
7db0: 65 6e 74 20 66 72 6f 6d 20 63 76 73 32 73 76 6e ent from cvs2svn
7dc0: 2e 20 4f 75 72 20 73 70 69 72 69 74 75 61 6c 20 . Our spiritual
7dd0: 61 6e 63 65 73 74 6f 72 0a 09 23 20 64 6f 65 73 ancestor..# does
7de0: 20 6e 6f 74 20 75 73 65 20 73 75 63 68 20 70 73 not use such ps
7df0: 65 75 64 6f 2d 64 65 70 65 6e 64 65 6e 63 69 65 eudo-dependencie
7e00: 73 2c 20 68 6f 77 65 76 65 72 20 69 74 20 75 73 s, however it us
7e10: 65 73 20 61 0a 09 23 20 43 4f 4d 4d 49 54 5f 54 es a..# COMMIT_T
7e20: 48 52 45 53 48 4f 4c 44 2c 20 61 20 74 69 6d 65 HRESHOLD, a time
7e30: 20 69 6e 74 65 72 76 61 6c 20 63 6f 6d 6d 69 74 interval commit
7e40: 73 20 73 68 6f 75 6c 64 20 66 61 6c 6c 2e 20 54 s should fall. T
7e50: 68 69 73 0a 09 23 20 77 69 6c 6c 20 67 72 65 61 his..# will grea
7e60: 74 6c 79 20 72 65 64 75 63 65 73 20 74 68 65 20 tly reduces the
7e70: 72 69 73 6b 20 6f 66 20 67 65 74 74 69 6e 67 20 risk of getting
7e80: 66 61 72 20 73 65 70 61 72 61 74 65 64 0a 09 23 far separated..#
7e90: 20 72 65 76 69 73 69 6f 6e 73 20 6f 66 20 74 68 revisions of th
7ea0: 65 20 73 61 6d 65 20 66 69 6c 65 20 69 6e 74 6f e same file into
7eb0: 20 6f 6e 65 20 63 68 61 6e 67 65 73 65 74 2e 0a one changeset..
7ec0: 0a 09 23 20 57 65 20 61 6c 6c 6f 77 20 72 65 76 ..# We allow rev
7ed0: 69 73 69 6f 6e 73 20 74 6f 20 62 65 20 66 61 72 isions to be far
7ee0: 20 61 70 61 72 74 20 69 6e 20 74 69 6d 65 20 69 apart in time i
7ef0: 6e 20 74 68 65 20 73 61 6d 65 0a 09 23 20 63 68 n the same..# ch
7f00: 61 6e 67 65 73 65 74 2c 20 62 75 74 20 69 6e 20 angeset, but in
7f10: 74 75 72 6e 20 6e 65 65 64 20 74 68 65 20 70 73 turn need the ps
7f20: 65 75 64 6f 2d 64 65 70 65 6e 64 65 6e 63 69 65 eudo-dependencie
7f30: 73 20 74 6f 0a 09 23 20 68 61 6e 64 6c 65 20 74 s to..# handle t
7f40: 68 69 73 2e 0a 0a 09 61 72 72 61 79 20 73 65 74 his....array set
7f50: 20 66 69 64 73 20 7b 7d 0a 09 66 6f 72 65 61 63 fids {}..foreac
7f60: 68 20 7b 72 69 64 20 66 69 64 7d 20 5b 73 74 61 h {rid fid} [sta
7f70: 74 65 20 72 75 6e 20 5b 73 75 62 73 74 20 2d 6e te run [subst -n
7f80: 6f 63 6f 6d 6d 61 6e 64 73 20 2d 6e 6f 62 61 63 ocommands -nobac
7f90: 6b 73 6c 61 73 68 65 73 20 7b 0a 09 20 20 20 20 kslashes {..
7fa0: 53 45 4c 45 43 54 20 52 2e 72 69 64 2c 20 52 2e SELECT R.rid, R.
7fb0: 66 69 64 0a 20 20 20 20 20 20 20 20 20 20 20 20 fid.
7fc0: 46 52 4f 4d 20 20 20 72 65 76 69 73 69 6f 6e 20 FROM revision
7fd0: 52 0a 20 20 20 20 20 20 20 20 20 20 20 20 57 48 R. WH
7fe0: 45 52 45 20 20 52 2e 72 69 64 20 49 4e 20 24 74 ERE R.rid IN $t
7ff0: 68 65 73 65 74 0a 09 7d 5d 5d 20 7b 20 6c 61 70 heset..}]] { lap
8000: 70 65 6e 64 20 66 69 64 73 28 24 66 69 64 29 20 pend fids($fid)
8010: 24 72 69 64 20 7d 0a 0a 09 66 6f 72 65 61 63 68 $rid }...foreach
8020: 20 7b 66 69 64 20 72 69 64 73 7d 20 5b 61 72 72 {fid rids} [arr
8030: 61 79 20 67 65 74 20 66 69 64 73 5d 20 7b 0a 09 ay get fids] {..
8040: 20 20 20 20 69 66 20 7b 5b 6c 6c 65 6e 67 74 68 if {[llength
8050: 20 24 72 69 64 73 5d 20 3c 20 32 7d 20 63 6f 6e $rids] < 2} con
8060: 74 69 6e 75 65 0a 09 20 20 20 20 66 6f 72 65 61 tinue.. forea
8070: 63 68 20 61 20 24 72 69 64 73 20 7b 0a 09 09 66 ch a $rids {...f
8080: 6f 72 65 61 63 68 20 62 20 24 72 69 64 73 20 7b oreach b $rids {
8090: 0a 09 09 20 20 20 20 69 66 20 7b 24 61 20 3d 3d ... if {$a ==
80a0: 20 24 62 7d 20 63 6f 6e 74 69 6e 75 65 0a 09 09 $b} continue...
80b0: 20 20 20 20 69 66 20 7b 5b 69 6e 66 6f 20 65 78 if {[info ex
80c0: 69 73 74 73 20 64 65 70 28 24 61 2c 24 62 29 5d ists dep($a,$b)]
80d0: 7d 20 63 6f 6e 74 69 6e 75 65 0a 09 09 20 20 20 } continue...
80e0: 20 69 66 20 7b 5b 69 6e 66 6f 20 65 78 69 73 74 if {[info exist
80f0: 73 20 64 65 70 28 24 62 2c 24 61 29 5d 7d 20 63 s dep($b,$a)]} c
8100: 6f 6e 74 69 6e 75 65 0a 09 09 20 20 20 20 6c 61 ontinue... la
8110: 70 70 65 6e 64 20 64 65 70 65 6e 64 65 6e 63 69 ppend dependenci
8120: 65 73 28 24 61 29 20 24 62 0a 09 09 20 20 20 20 es($a) $b...
8130: 73 65 74 20 64 65 70 28 24 61 2c 24 62 29 20 2e set dep($a,$b) .
8140: 0a 09 09 20 20 20 20 73 65 74 20 64 65 70 28 24 ... set dep($
8150: 62 2c 24 61 29 20 2e 0a 09 09 7d 0a 09 20 20 20 b,$a) ....}..
8160: 20 7d 0a 09 7d 0a 09 72 65 74 75 72 6e 0a 20 20 }..}..return.
8170: 20 20 7d 0a 0a 20 20 20 20 23 20 72 65 73 75 6c }.. # resul
8180: 74 20 3d 20 34 2d 6c 69 73 74 20 28 69 74 65 6d t = 4-list (item
8190: 74 79 70 65 20 69 74 65 6d 69 64 20 6e 65 78 74 type itemid next
81a0: 69 74 65 6d 74 79 70 65 20 6e 65 78 74 69 74 65 itemtype nextite
81b0: 6d 69 64 20 2e 2e 2e 29 0a 20 20 20 20 74 79 70 mid ...). typ
81c0: 65 6d 65 74 68 6f 64 20 6c 6f 6f 70 73 20 7b 72 emethod loops {r
81d0: 65 76 69 73 69 6f 6e 73 7d 20 7b 0a 09 23 20 4e evisions} {..# N
81e0: 6f 74 65 3a 20 54 61 67 73 20 61 6e 64 20 62 72 ote: Tags and br
81f0: 61 6e 63 68 65 73 20 63 61 6e 6e 6f 74 20 63 61 anches cannot ca
8200: 75 73 65 20 74 68 65 20 6c 6f 6f 70 2e 20 54 68 use the loop. Th
8210: 65 69 72 20 69 64 27 73 2c 0a 09 23 20 62 65 69 eir id's,..# bei
8220: 6e 67 20 6f 66 20 61 20 66 75 6e 64 61 6d 65 6e ng of a fundamen
8230: 74 61 6c 6c 79 20 64 69 66 66 65 72 65 6e 74 20 tally different
8240: 74 79 70 65 20 74 68 61 6e 20 74 68 65 20 72 65 type than the re
8250: 76 69 73 69 6f 6e 73 0a 09 23 20 63 6f 6d 69 6e visions..# comin
8260: 67 20 69 6e 20 63 61 6e 6e 6f 74 20 62 65 20 69 g in cannot be i
8270: 6e 20 74 68 65 20 73 65 74 2e 0a 0a 09 73 65 74 n the set....set
8280: 20 74 68 65 73 65 74 20 28 27 5b 6a 6f 69 6e 20 theset ('[join
8290: 24 72 65 76 69 73 69 6f 6e 73 20 7b 27 2c 27 7d $revisions {','}
82a0: 5d 27 29 0a 09 72 65 74 75 72 6e 20 5b 73 74 61 ]')..return [sta
82b0: 74 65 20 72 75 6e 20 5b 73 75 62 73 74 20 2d 6e te run [subst -n
82c0: 6f 63 6f 6d 6d 61 6e 64 73 20 2d 6e 6f 62 61 63 ocommands -nobac
82d0: 6b 73 6c 61 73 68 65 73 20 7b 0a 09 20 20 20 20 kslashes {..
82e0: 2d 2d 20 28 31 29 20 50 72 69 6d 61 72 79 20 63 -- (1) Primary c
82f0: 68 69 6c 64 0a 09 20 20 20 20 53 45 4c 45 43 54 hild.. SELECT
8300: 20 52 2e 72 69 64 2c 20 52 2e 63 68 69 6c 64 0a R.rid, R.child.
8310: 09 20 20 20 20 46 52 4f 4d 20 20 20 72 65 76 69 . FROM revi
8320: 73 69 6f 6e 20 52 0a 09 20 20 20 20 57 48 45 52 sion R.. WHER
8330: 45 20 20 52 2e 72 69 64 20 20 20 49 4e 20 24 74 E R.rid IN $t
8340: 68 65 73 65 74 20 20 20 20 20 2d 2d 20 52 65 73 heset -- Res
8350: 74 72 69 63 74 20 74 6f 20 72 65 76 69 73 69 6f trict to revisio
8360: 6e 73 20 6f 66 20 69 6e 74 65 72 65 73 74 0a 09 ns of interest..
8370: 20 20 20 20 41 4e 44 20 20 20 20 52 2e 63 68 69 AND R.chi
8380: 6c 64 20 49 53 20 4e 4f 54 20 4e 55 4c 4c 20 20 ld IS NOT NULL
8390: 20 20 2d 2d 20 48 61 73 20 70 72 69 6d 61 72 79 -- Has primary
83a0: 20 63 68 69 6c 64 0a 09 20 20 20 20 41 4e 44 20 child.. AND
83b0: 20 20 20 52 2e 63 68 69 6c 64 20 49 4e 20 24 74 R.child IN $t
83c0: 68 65 73 65 74 20 20 20 20 20 2d 2d 20 4c 6f 6f heset -- Loo
83d0: 70 0a 09 20 20 20 20 2d 2d 0a 09 20 20 20 20 55 p.. --.. U
83e0: 4e 49 4f 4e 0a 09 20 20 20 20 2d 2d 20 28 32 29 NION.. -- (2)
83f0: 20 53 65 63 6f 6e 64 61 72 79 20 28 62 72 61 6e Secondary (bran
8400: 63 68 29 20 63 68 69 6c 64 72 65 6e 0a 09 20 20 ch) children..
8410: 20 20 53 45 4c 45 43 54 20 52 2e 72 69 64 2c 20 SELECT R.rid,
8420: 42 2e 62 72 69 64 0a 09 20 20 20 20 46 52 4f 4d B.brid.. FROM
8430: 20 20 20 72 65 76 69 73 69 6f 6e 20 52 2c 20 72 revision R, r
8440: 65 76 69 73 69 6f 6e 62 72 61 6e 63 68 63 68 69 evisionbranchchi
8450: 6c 64 72 65 6e 20 42 0a 09 20 20 20 20 57 48 45 ldren B.. WHE
8460: 52 45 20 20 52 2e 72 69 64 20 20 20 49 4e 20 24 RE R.rid IN $
8470: 74 68 65 73 65 74 20 20 20 20 20 2d 2d 20 52 65 theset -- Re
8480: 73 74 72 69 63 74 20 74 6f 20 72 65 76 69 73 69 strict to revisi
8490: 6f 6e 73 20 6f 66 20 69 6e 74 65 72 65 73 74 0a ons of interest.
84a0: 09 20 20 20 20 41 4e 44 20 20 20 20 52 2e 72 69 . AND R.ri
84b0: 64 20 3d 20 42 2e 72 69 64 20 20 20 20 20 20 20 d = B.rid
84c0: 20 20 20 2d 2d 20 53 65 6c 65 63 74 20 73 75 62 -- Select sub
84d0: 73 65 74 20 6f 66 20 62 72 61 6e 63 68 20 63 68 set of branch ch
84e0: 69 6c 64 72 65 6e 0a 09 20 20 20 20 41 4e 44 20 ildren.. AND
84f0: 20 20 20 42 2e 72 69 64 20 20 20 49 4e 20 24 74 B.rid IN $t
8500: 68 65 73 65 74 20 20 20 20 20 2d 2d 20 4c 6f 6f heset -- Loo
8510: 70 0a 09 20 20 20 20 2d 2d 0a 09 20 20 20 20 55 p.. --.. U
8520: 4e 49 4f 4e 0a 09 20 20 20 20 2d 2d 20 28 34 29 NION.. -- (4)
8530: 20 43 68 69 6c 64 20 6f 66 20 74 72 75 6e 6b 20 Child of trunk
8540: 72 6f 6f 74 20 73 75 63 63 65 73 73 6f 72 20 6f root successor o
8550: 66 20 6c 61 73 74 20 4e 54 44 42 20 6f 6e 20 74 f last NTDB on t
8560: 72 75 6e 6b 2e 0a 09 20 20 20 20 53 45 4c 45 43 runk... SELEC
8570: 54 20 52 2e 72 69 64 2c 20 52 41 2e 63 68 69 6c T R.rid, RA.chil
8580: 64 0a 09 20 20 20 20 46 52 4f 4d 20 20 20 72 65 d.. FROM re
8590: 76 69 73 69 6f 6e 20 52 2c 20 72 65 76 69 73 69 vision R, revisi
85a0: 6f 6e 20 52 41 0a 09 20 20 20 20 57 48 45 52 45 on RA.. WHERE
85b0: 20 20 52 2e 72 69 64 20 20 20 20 49 4e 20 24 74 R.rid IN $t
85c0: 68 65 73 65 74 20 20 20 20 20 2d 2d 20 52 65 73 heset -- Res
85d0: 74 72 69 63 74 20 74 6f 20 72 65 76 69 73 69 6f trict to revisio
85e0: 6e 73 20 6f 66 20 69 6e 74 65 72 65 73 74 0a 09 ns of interest..
85f0: 20 20 20 20 41 4e 44 20 20 20 20 52 2e 69 73 64 AND R.isd
8600: 65 66 61 75 6c 74 20 20 20 20 20 20 20 20 20 20 efault
8610: 20 20 20 2d 2d 20 52 65 73 74 72 69 63 74 20 74 -- Restrict t
8620: 6f 20 4e 54 44 42 0a 09 20 20 20 20 41 4e 44 20 o NTDB.. AND
8630: 20 20 20 52 2e 64 62 63 68 69 6c 64 20 49 53 20 R.dbchild IS
8640: 4e 4f 54 20 4e 55 4c 4c 20 20 20 2d 2d 20 61 6e NOT NULL -- an
8650: 64 20 6c 61 73 74 20 4e 54 44 42 20 62 65 6c 6f d last NTDB belo
8660: 6e 67 69 6e 67 20 74 6f 20 74 72 75 6e 6b 0a 09 nging to trunk..
8670: 20 20 20 20 41 4e 44 20 20 20 20 52 41 2e 72 69 AND RA.ri
8680: 64 20 3d 20 52 2e 64 62 63 68 69 6c 64 20 20 20 d = R.dbchild
8690: 20 20 20 2d 2d 20 47 6f 20 64 69 72 65 63 74 6c -- Go directl
86a0: 79 20 74 6f 20 74 72 75 6e 6b 20 72 6f 6f 74 0a y to trunk root.
86b0: 09 20 20 20 20 41 4e 44 20 20 20 20 52 41 2e 63 . AND RA.c
86c0: 68 69 6c 64 20 49 53 20 4e 4f 54 20 4e 55 4c 4c hild IS NOT NULL
86d0: 20 20 20 20 2d 2d 20 48 61 73 20 70 72 69 6d 61 -- Has prima
86e0: 72 79 20 63 68 69 6c 64 2e 0a 09 20 20 20 20 41 ry child... A
86f0: 4e 44 20 20 20 20 52 41 2e 63 68 69 6c 64 20 49 ND RA.child I
8700: 4e 20 24 74 68 65 73 65 74 20 20 20 20 20 2d 2d N $theset --
8710: 20 4c 6f 6f 70 0a 09 7d 5d 5d 0a 20 20 20 20 7d Loop..}]]. }
8720: 0a 0a 20 20 20 20 23 20 76 61 72 28 64 76 29 20 .. # var(dv)
8730: 3d 20 64 69 63 74 20 28 69 74 65 6d 20 2d 3e 20 = dict (item ->
8740: 6c 69 73 74 20 28 69 74 65 6d 29 29 2c 20 69 74 list (item)), it
8750: 65 6d 20 20 3d 20 6c 69 73 74 20 28 74 79 70 65 em = list (type
8760: 20 69 64 29 0a 20 20 20 20 74 79 70 65 6d 65 74 id). typemet
8770: 68 6f 64 20 73 75 63 63 65 73 73 6f 72 73 20 7b hod successors {
8780: 64 76 20 72 65 76 69 73 69 6f 6e 73 7d 20 7b 0a dv revisions} {.
8790: 09 75 70 76 61 72 20 31 20 24 64 76 20 64 65 70 .upvar 1 $dv dep
87a0: 65 6e 64 65 6e 63 69 65 73 0a 09 73 65 74 20 74 endencies..set t
87b0: 68 65 73 65 74 20 28 27 5b 6a 6f 69 6e 20 24 72 heset ('[join $r
87c0: 65 76 69 73 69 6f 6e 73 20 7b 27 2c 27 7d 5d 27 evisions {','}]'
87d0: 29 0a 0a 09 23 20 54 68 65 20 66 6f 6c 6c 6f 77 )...# The follow
87e0: 69 6e 67 20 63 61 73 65 73 20 73 70 65 63 69 66 ing cases specif
87f0: 79 20 77 68 65 6e 20 61 20 72 65 76 69 73 69 6f y when a revisio
8800: 6e 20 53 20 69 73 20 61 20 73 75 63 63 65 73 73 n S is a success
8810: 6f 72 0a 09 23 20 6f 66 20 61 20 72 65 76 69 73 or..# of a revis
8820: 69 6f 6e 20 52 2e 20 45 61 63 68 20 6f 66 20 74 ion R. Each of t
8830: 68 65 20 63 61 73 65 73 20 74 72 61 6e 73 6c 61 he cases transla
8840: 74 65 73 20 69 6e 74 6f 20 6f 6e 65 20 6f 66 0a tes into one of.
8850: 09 23 20 74 68 65 20 62 72 61 6e 63 68 65 73 20 .# the branches
8860: 6f 66 20 74 68 65 20 53 51 4c 20 55 4e 49 4f 4e of the SQL UNION
8870: 20 63 6f 6d 69 6e 67 20 62 65 6c 6f 77 2e 0a 09 coming below...
8880: 23 0a 09 23 20 28 31 29 20 53 20 63 61 6e 20 62 #..# (1) S can b
8890: 65 20 61 20 70 72 69 6d 61 72 79 20 63 68 69 6c e a primary chil
88a0: 64 20 6f 66 20 52 2c 20 69 2e 65 2e 20 69 6e 20 d of R, i.e. in
88b0: 74 68 65 20 73 61 6d 65 20 4c 4f 44 2e 20 52 0a the same LOD. R.
88c0: 09 23 20 20 20 20 20 72 65 66 65 72 65 6e 63 65 .# reference
88d0: 73 20 53 20 64 69 72 65 63 74 6c 79 2e 20 52 2e s S directly. R.
88e0: 63 68 69 6c 64 20 3d 20 53 28 2e 72 69 64 29 2c child = S(.rid),
88f0: 20 69 66 20 69 74 20 65 78 69 73 74 73 2e 0a 09 if it exists...
8900: 23 0a 09 23 20 28 32 29 20 53 20 63 61 6e 20 62 #..# (2) S can b
8910: 65 20 61 20 73 65 63 6f 6e 64 61 72 79 2c 20 69 e a secondary, i
8920: 2e 65 2e 20 62 72 61 6e 63 68 2c 20 63 68 69 6c .e. branch, chil
8930: 64 20 6f 66 20 52 2e 20 48 65 72 65 20 74 68 65 d of R. Here the
8940: 0a 09 23 20 20 20 20 20 6c 69 6e 6b 20 69 73 20 ..# link is
8950: 6d 61 64 65 20 74 68 72 6f 75 67 68 20 74 68 65 made through the
8960: 20 68 65 6c 70 65 72 20 74 61 62 6c 65 0a 09 23 helper table..#
8970: 20 20 20 20 20 52 45 56 49 53 49 4f 4e 42 52 41 REVISIONBRA
8980: 4e 43 48 43 48 49 4c 44 52 45 4e 2e 20 52 2e 72 NCHCHILDREN. R.r
8990: 69 64 20 2d 3e 20 52 42 43 2e 72 69 64 2c 20 52 id -> RBC.rid, R
89a0: 42 43 2e 62 72 69 64 20 3d 0a 09 23 20 20 20 20 BC.brid =..#
89b0: 20 53 28 2e 72 69 64 29 0a 09 23 0a 09 23 20 28 S(.rid)..#..# (
89c0: 33 29 20 4f 72 69 67 69 6e 61 6c 6c 79 20 74 68 3) Originally th
89d0: 69 73 20 75 73 65 20 63 61 73 65 20 64 65 66 69 is use case defi
89e0: 6e 65 64 20 74 68 65 20 72 6f 6f 74 20 6f 66 20 ned the root of
89f0: 61 20 64 65 74 61 63 68 65 64 0a 09 23 20 20 20 a detached..#
8a00: 20 20 4e 54 44 42 20 61 73 20 74 68 65 20 73 75 NTDB as the su
8a10: 63 63 65 73 73 6f 72 20 6f 66 20 74 68 65 20 74 ccessor of the t
8a20: 72 75 6e 6b 20 72 6f 6f 74 2e 20 54 68 69 73 20 runk root. This
8a30: 6c 65 61 64 73 20 74 6f 20 61 0a 09 23 20 20 20 leads to a..#
8a40: 20 20 62 61 64 20 74 61 6e 67 6c 65 20 6c 61 74 bad tangle lat
8a50: 65 72 20 6f 6e 2e 20 57 69 74 68 20 61 20 64 65 er on. With a de
8a60: 74 61 63 68 65 64 20 4e 54 44 42 20 74 68 65 20 tached NTDB the
8a70: 6f 72 69 67 69 6e 61 6c 0a 09 23 20 20 20 20 20 original..#
8a80: 74 72 75 6e 6b 20 72 6f 6f 74 20 72 65 76 69 73 trunk root revis
8a90: 69 6f 6e 20 77 61 73 20 72 65 6d 6f 76 65 64 20 ion was removed
8aa0: 61 73 20 69 72 72 65 6c 65 76 61 6e 74 2c 20 61 as irrelevant, a
8ab0: 6c 6c 6f 77 69 6e 67 0a 09 23 20 20 20 20 20 74 llowing..# t
8ac0: 68 65 20 6e 6f 6d 69 6e 61 6c 20 72 6f 6f 74 20 he nominal root
8ad0: 74 6f 20 62 65 20 6c 61 74 65 72 20 69 6e 20 74 to be later in t
8ae0: 69 6d 65 20 74 68 61 6e 20 74 68 65 20 4e 54 44 ime than the NTD
8af0: 42 0a 09 23 20 20 20 20 20 72 6f 6f 74 2e 20 4e B..# root. N
8b00: 6f 77 20 73 65 74 74 69 6e 67 20 74 68 69 73 20 ow setting this
8b10: 64 65 70 65 6e 64 65 6e 63 79 20 77 69 6c 6c 20 dependency will
8b20: 62 65 20 62 61 63 6b 77 61 72 64 20 69 6e 0a 09 be backward in..
8b30: 23 20 20 20 20 20 74 69 6d 65 2e 20 52 45 4d 4f # time. REMO
8b40: 56 45 44 2e 0a 09 23 0a 09 23 20 28 34 29 20 49 VED...#..# (4) I
8b50: 66 20 52 20 69 73 20 74 68 65 20 6c 61 73 74 20 f R is the last
8b60: 6f 66 20 74 68 65 20 4e 54 44 42 20 72 65 76 69 of the NTDB revi
8b70: 73 69 6f 6e 73 20 77 68 69 63 68 20 62 65 6c 6f sions which belo
8b80: 6e 67 20 74 6f 0a 09 23 20 20 20 20 20 74 68 65 ng to..# the
8b90: 20 74 72 75 6e 6b 2c 20 74 68 65 6e 20 74 68 65 trunk, then the
8ba0: 20 70 72 69 6d 61 72 79 20 63 68 69 6c 64 20 6f primary child o
8bb0: 66 20 74 68 65 20 74 72 75 6e 6b 20 72 6f 6f 74 f the trunk root
8bc0: 20 28 74 68 65 0a 09 23 20 20 20 20 20 27 31 2e (the..# '1.
8bd0: 32 27 20 72 65 76 69 73 69 6f 6e 29 20 69 73 20 2' revision) is
8be0: 61 20 73 75 63 63 65 73 73 6f 72 2c 20 69 66 20 a successor, if
8bf0: 69 74 20 65 78 69 73 74 73 2e 0a 0a 09 23 20 4e it exists....# N
8c00: 6f 74 65 20 74 68 61 74 20 74 68 65 20 62 72 61 ote that the bra
8c10: 6e 63 68 65 73 20 73 70 61 77 6e 65 64 20 66 72 nches spawned fr
8c20: 6f 6d 20 74 68 65 20 72 65 76 69 73 69 6f 6e 73 om the revisions
8c30: 2c 20 61 6e 64 20 74 68 65 0a 09 23 20 74 61 67 , and the..# tag
8c40: 73 20 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 s associated wit
8c50: 68 20 74 68 65 6d 20 61 72 65 20 73 75 63 63 65 h them are succe
8c60: 73 73 6f 72 73 20 61 73 20 77 65 6c 6c 2e 0a 0a ssors as well...
8c70: 09 66 6f 72 65 61 63 68 20 7b 72 69 64 20 63 68 .foreach {rid ch
8c80: 69 6c 64 7d 20 5b 73 74 61 74 65 20 72 75 6e 20 ild} [state run
8c90: 5b 73 75 62 73 74 20 2d 6e 6f 63 6f 6d 6d 61 6e [subst -nocomman
8ca0: 64 73 20 2d 6e 6f 62 61 63 6b 73 6c 61 73 68 65 ds -nobackslashe
8cb0: 73 20 7b 0a 20 20 20 20 2d 2d 20 28 31 29 20 50 s {. -- (1) P
8cc0: 72 69 6d 61 72 79 20 63 68 69 6c 64 0a 09 20 20 rimary child..
8cd0: 20 20 53 45 4c 45 43 54 20 52 2e 72 69 64 2c 20 SELECT R.rid,
8ce0: 52 2e 63 68 69 6c 64 0a 09 20 20 20 20 46 52 4f R.child.. FRO
8cf0: 4d 20 20 20 72 65 76 69 73 69 6f 6e 20 52 0a 09 M revision R..
8d00: 20 20 20 20 57 48 45 52 45 20 20 52 2e 72 69 64 WHERE R.rid
8d10: 20 20 20 49 4e 20 24 74 68 65 73 65 74 20 20 20 IN $theset
8d20: 20 20 2d 2d 20 52 65 73 74 72 69 63 74 20 74 6f -- Restrict to
8d30: 20 72 65 76 69 73 69 6f 6e 73 20 6f 66 20 69 6e revisions of in
8d40: 74 65 72 65 73 74 0a 09 20 20 20 20 41 4e 44 20 terest.. AND
8d50: 20 20 20 52 2e 63 68 69 6c 64 20 49 53 20 4e 4f R.child IS NO
8d60: 54 20 4e 55 4c 4c 20 20 20 20 2d 2d 20 48 61 73 T NULL -- Has
8d70: 20 70 72 69 6d 61 72 79 20 63 68 69 6c 64 0a 20 primary child.
8d80: 20 20 20 55 4e 49 4f 4e 0a 20 20 20 20 2d 2d 20 UNION. --
8d90: 28 32 29 20 53 65 63 6f 6e 64 61 72 79 20 28 62 (2) Secondary (b
8da0: 72 61 6e 63 68 29 20 63 68 69 6c 64 72 65 6e 0a ranch) children.
8db0: 09 20 20 20 20 53 45 4c 45 43 54 20 52 2e 72 69 . SELECT R.ri
8dc0: 64 2c 20 42 2e 62 72 69 64 0a 09 20 20 20 20 46 d, B.brid.. F
8dd0: 52 4f 4d 20 20 20 72 65 76 69 73 69 6f 6e 20 52 ROM revision R
8de0: 2c 20 72 65 76 69 73 69 6f 6e 62 72 61 6e 63 68 , revisionbranch
8df0: 63 68 69 6c 64 72 65 6e 20 42 0a 09 20 20 20 20 children B..
8e00: 57 48 45 52 45 20 20 52 2e 72 69 64 20 20 20 49 WHERE R.rid I
8e10: 4e 20 24 74 68 65 73 65 74 20 20 20 20 20 2d 2d N $theset --
8e20: 20 52 65 73 74 72 69 63 74 20 74 6f 20 72 65 76 Restrict to rev
8e30: 69 73 69 6f 6e 73 20 6f 66 20 69 6e 74 65 72 65 isions of intere
8e40: 73 74 0a 09 20 20 20 20 41 4e 44 20 20 20 20 52 st.. AND R
8e50: 2e 72 69 64 20 3d 20 42 2e 72 69 64 20 20 20 20 .rid = B.rid
8e60: 20 20 20 20 20 20 2d 2d 20 53 65 6c 65 63 74 20 -- Select
8e70: 73 75 62 73 65 74 20 6f 66 20 62 72 61 6e 63 68 subset of branch
8e80: 20 63 68 69 6c 64 72 65 6e 0a 20 20 20 20 55 4e children. UN
8e90: 49 4f 4e 0a 20 20 20 20 2d 2d 20 28 34 29 20 43 ION. -- (4) C
8ea0: 68 69 6c 64 20 6f 66 20 74 72 75 6e 6b 20 72 6f hild of trunk ro
8eb0: 6f 74 20 73 75 63 63 65 73 73 6f 72 20 6f 66 20 ot successor of
8ec0: 6c 61 73 74 20 4e 54 44 42 20 6f 6e 20 74 72 75 last NTDB on tru
8ed0: 6e 6b 2e 0a 09 20 20 20 20 53 45 4c 45 43 54 20 nk... SELECT
8ee0: 52 2e 72 69 64 2c 20 52 41 2e 63 68 69 6c 64 0a R.rid, RA.child.
8ef0: 09 20 20 20 20 46 52 4f 4d 20 72 65 76 69 73 69 . FROM revisi
8f00: 6f 6e 20 52 2c 20 72 65 76 69 73 69 6f 6e 20 52 on R, revision R
8f10: 41 0a 09 20 20 20 20 57 48 45 52 45 20 52 2e 72 A.. WHERE R.r
8f20: 69 64 20 20 20 49 4e 20 24 74 68 65 73 65 74 20 id IN $theset
8f30: 20 20 20 20 20 2d 2d 20 52 65 73 74 72 69 63 74 -- Restrict
8f40: 20 74 6f 20 72 65 76 69 73 69 6f 6e 73 20 6f 66 to revisions of
8f50: 20 69 6e 74 65 72 65 73 74 0a 09 20 20 20 20 41 interest.. A
8f60: 4e 44 20 20 20 52 2e 69 73 64 65 66 61 75 6c 74 ND R.isdefault
8f70: 20 20 20 20 20 20 20 20 20 20 20 20 20 2d 2d 20 --
8f80: 52 65 73 74 72 69 63 74 20 74 6f 20 4e 54 44 42 Restrict to NTDB
8f90: 0a 09 20 20 20 20 41 4e 44 20 20 20 52 2e 64 62 .. AND R.db
8fa0: 63 68 69 6c 64 20 49 53 20 4e 4f 54 20 4e 55 4c child IS NOT NUL
8fb0: 4c 20 20 20 2d 2d 20 61 6e 64 20 6c 61 73 74 20 L -- and last
8fc0: 4e 54 44 42 20 62 65 6c 6f 6e 67 69 6e 67 20 74 NTDB belonging t
8fd0: 6f 20 74 72 75 6e 6b 0a 09 20 20 20 20 41 4e 44 o trunk.. AND
8fe0: 20 20 20 52 41 2e 72 69 64 20 3d 20 52 2e 64 62 RA.rid = R.db
8ff0: 63 68 69 6c 64 20 20 20 20 20 20 2d 2d 20 47 6f child -- Go
9000: 20 64 69 72 65 63 74 6c 79 20 74 6f 20 74 72 75 directly to tru
9010: 6e 6b 20 72 6f 6f 74 0a 09 20 20 20 20 41 4e 44 nk root.. AND
9020: 20 20 20 52 41 2e 63 68 69 6c 64 20 49 53 20 4e RA.child IS N
9030: 4f 54 20 4e 55 4c 4c 20 20 20 20 2d 2d 20 48 61 OT NULL -- Ha
9040: 73 20 70 72 69 6d 61 72 79 20 63 68 69 6c 64 2e s primary child.
9050: 0a 09 7d 5d 5d 20 7b 0a 09 20 20 20 20 23 20 43 ..}]] {.. # C
9060: 6f 6e 73 69 64 65 72 20 6d 6f 76 69 6e 67 20 74 onsider moving t
9070: 68 69 73 20 74 6f 20 74 68 65 20 69 6e 74 65 67 his to the integ
9080: 72 69 74 79 20 6d 6f 64 75 6c 65 2e 0a 09 20 20 rity module...
9090: 20 20 69 6e 74 65 67 72 69 74 79 20 61 73 73 65 integrity asse
90a0: 72 74 20 7b 24 72 69 64 20 21 3d 20 24 63 68 69 rt {$rid != $chi
90b0: 6c 64 7d 20 7b 52 65 76 69 73 69 6f 6e 20 24 72 ld} {Revision $r
90c0: 69 64 20 64 65 70 65 6e 64 73 20 6f 6e 20 69 74 id depends on it
90d0: 73 65 6c 66 2e 7d 0a 09 20 20 20 20 6c 61 70 70 self.}.. lapp
90e0: 65 6e 64 20 64 65 70 65 6e 64 65 6e 63 69 65 73 end dependencies
90f0: 28 5b 6c 69 73 74 20 72 65 76 20 24 72 69 64 5d ([list rev $rid]
9100: 29 20 5b 6c 69 73 74 20 72 65 76 20 24 63 68 69 ) [list rev $chi
9110: 6c 64 5d 0a 09 7d 0a 09 66 6f 72 65 61 63 68 20 ld]..}..foreach
9120: 7b 72 69 64 20 63 68 69 6c 64 7d 20 5b 73 74 61 {rid child} [sta
9130: 74 65 20 72 75 6e 20 5b 73 75 62 73 74 20 2d 6e te run [subst -n
9140: 6f 63 6f 6d 6d 61 6e 64 73 20 2d 6e 6f 62 61 63 ocommands -nobac
9150: 6b 73 6c 61 73 68 65 73 20 7b 0a 09 20 20 20 20 kslashes {..
9160: 53 45 4c 45 43 54 20 52 2e 72 69 64 2c 20 54 2e SELECT R.rid, T.
9170: 74 69 64 0a 09 20 20 20 20 46 52 4f 4d 20 20 20 tid.. FROM
9180: 72 65 76 69 73 69 6f 6e 20 52 2c 20 74 61 67 20 revision R, tag
9190: 54 0a 09 20 20 20 20 57 48 45 52 45 20 20 52 2e T.. WHERE R.
91a0: 72 69 64 20 49 4e 20 24 74 68 65 73 65 74 20 20 rid IN $theset
91b0: 20 20 20 20 20 2d 2d 20 52 65 73 74 72 69 63 74 -- Restrict
91c0: 20 74 6f 20 72 65 76 69 73 69 6f 6e 73 20 6f 66 to revisions of
91d0: 20 69 6e 74 65 72 65 73 74 0a 09 20 20 20 20 41 interest.. A
91e0: 4e 44 20 20 20 20 54 2e 72 65 76 20 3d 20 52 2e ND T.rev = R.
91f0: 72 69 64 20 20 20 20 20 20 20 20 20 20 2d 2d 20 rid --
9200: 53 65 6c 65 63 74 20 74 61 67 73 20 61 74 74 61 Select tags atta
9210: 63 68 65 64 20 74 6f 20 74 68 65 6d 0a 09 7d 5d ched to them..}]
9220: 5d 20 7b 0a 09 20 20 20 20 6c 61 70 70 65 6e 64 ] {.. lappend
9230: 20 64 65 70 65 6e 64 65 6e 63 69 65 73 28 5b 6c dependencies([l
9240: 69 73 74 20 72 65 76 20 24 72 69 64 5d 29 20 5b ist rev $rid]) [
9250: 6c 69 73 74 20 73 79 6d 3a 3a 74 61 67 20 24 63 list sym::tag $c
9260: 68 69 6c 64 5d 0a 09 7d 0a 09 66 6f 72 65 61 63 hild]..}..foreac
9270: 68 20 7b 72 69 64 20 63 68 69 6c 64 7d 20 5b 73 h {rid child} [s
9280: 74 61 74 65 20 72 75 6e 20 5b 73 75 62 73 74 20 tate run [subst
9290: 2d 6e 6f 63 6f 6d 6d 61 6e 64 73 20 2d 6e 6f 62 -nocommands -nob
92a0: 61 63 6b 73 6c 61 73 68 65 73 20 7b 0a 09 20 20 ackslashes {..
92b0: 20 20 53 45 4c 45 43 54 20 52 2e 72 69 64 2c 20 SELECT R.rid,
92c0: 42 2e 62 69 64 0a 09 20 20 20 20 46 52 4f 4d 20 B.bid.. FROM
92d0: 20 20 72 65 76 69 73 69 6f 6e 20 52 2c 20 62 72 revision R, br
92e0: 61 6e 63 68 20 42 0a 09 20 20 20 20 57 48 45 52 anch B.. WHER
92f0: 45 20 20 52 2e 72 69 64 20 49 4e 20 24 74 68 65 E R.rid IN $the
9300: 73 65 74 20 20 20 20 20 20 20 2d 2d 20 52 65 73 set -- Res
9310: 74 72 69 63 74 20 74 6f 20 72 65 76 69 73 69 6f trict to revisio
9320: 6e 73 20 6f 66 20 69 6e 74 65 72 65 73 74 0a 09 ns of interest..
9330: 20 20 20 20 41 4e 44 20 20 20 20 42 2e 72 6f 6f AND B.roo
9340: 74 20 3d 20 52 2e 72 69 64 20 20 20 20 20 20 20 t = R.rid
9350: 20 20 2d 2d 20 53 65 6c 65 63 74 20 62 72 61 6e -- Select bran
9360: 63 68 65 73 20 61 74 74 61 63 68 65 64 20 74 6f ches attached to
9370: 20 74 68 65 6d 0a 09 7d 5d 5d 20 7b 0a 09 20 20 them..}]] {..
9380: 20 20 6c 61 70 70 65 6e 64 20 64 65 70 65 6e 64 lappend depend
9390: 65 6e 63 69 65 73 28 5b 6c 69 73 74 20 72 65 76 encies([list rev
93a0: 20 24 72 69 64 5d 29 20 5b 6c 69 73 74 20 73 79 $rid]) [list sy
93b0: 6d 3a 3a 62 72 61 6e 63 68 20 24 63 68 69 6c 64 m::branch $child
93c0: 5d 0a 09 7d 0a 09 72 65 74 75 72 6e 0a 20 20 20 ]..}..return.
93d0: 20 7d 0a 0a 20 20 20 20 23 20 72 65 73 75 6c 74 }.. # result
93e0: 20 3d 20 6c 69 73 74 20 28 63 68 61 6e 67 65 73 = list (changes
93f0: 65 74 2d 69 64 29 0a 20 20 20 20 74 79 70 65 6d et-id). typem
9400: 65 74 68 6f 64 20 63 73 5f 73 75 63 63 65 73 73 ethod cs_success
9410: 6f 72 73 20 7b 72 65 76 69 73 69 6f 6e 73 7d 20 ors {revisions}
9420: 7b 0a 20 20 20 20 20 20 20 20 23 20 54 68 69 73 {. # This
9430: 20 69 73 20 61 20 76 61 72 69 61 6e 74 20 6f 66 is a variant of
9440: 20 27 73 75 63 63 65 73 73 6f 72 73 27 20 77 68 'successors' wh
9450: 69 63 68 20 6d 61 70 73 20 74 68 65 20 6c 6f 77 ich maps the low
9460: 2d 6c 65 76 65 6c 0a 20 20 20 20 20 20 20 20 23 -level. #
9470: 20 64 61 74 61 20 64 69 72 65 63 74 6c 79 20 74 data directly t
9480: 6f 20 74 68 65 20 61 73 73 6f 63 69 61 74 65 64 o the associated
9490: 20 63 68 61 6e 67 65 73 65 74 73 2e 20 49 2e 65 changesets. I.e
94a0: 2e 20 69 6e 73 74 65 61 64 0a 20 20 20 20 20 20 . instead.
94b0: 20 20 23 20 6d 69 6c 6c 69 6f 6e 73 20 6f 66 20 # millions of
94c0: 64 65 70 65 6e 64 65 6e 63 79 20 70 61 69 72 73 dependency pairs
94d0: 20 28 69 6e 20 65 78 74 72 65 6d 65 20 63 61 73 (in extreme cas
94e0: 65 73 20 28 45 78 61 6d 70 6c 65 3a 20 54 63 6c es (Example: Tcl
94f0: 0a 20 20 20 20 20 20 20 20 23 20 43 56 53 29 29 . # CVS))
9500: 20 77 65 20 72 65 74 75 72 6e 20 61 20 76 65 72 we return a ver
9510: 79 20 73 68 6f 72 74 20 61 6e 64 20 6d 75 63 68 y short and much
9520: 20 6d 6f 72 65 20 6d 61 6e 61 67 65 61 62 6c 65 more manageable
9530: 20 6c 69 73 74 0a 20 20 20 20 20 20 20 20 23 20 list. #
9540: 6f 66 20 63 68 61 6e 67 65 73 65 74 73 2e 0a 0a of changesets...
9550: 09 73 65 74 20 74 68 65 73 65 74 20 28 27 5b 6a .set theset ('[j
9560: 6f 69 6e 20 24 72 65 76 69 73 69 6f 6e 73 20 7b oin $revisions {
9570: 27 2c 27 7d 5d 27 29 0a 09 72 65 74 75 72 6e 20 ','}]')..return
9580: 5b 73 74 61 74 65 20 72 75 6e 20 5b 73 75 62 73 [state run [subs
9590: 74 20 2d 6e 6f 63 6f 6d 6d 61 6e 64 73 20 2d 6e t -nocommands -n
95a0: 6f 62 61 63 6b 73 6c 61 73 68 65 73 20 7b 0a 20 obackslashes {.
95b0: 20 20 20 2d 2d 20 28 31 29 20 50 72 69 6d 61 72 -- (1) Primar
95c0: 79 20 63 68 69 6c 64 0a 09 20 20 20 20 53 45 4c y child.. SEL
95d0: 45 43 54 20 43 2e 63 69 64 0a 09 20 20 20 20 46 ECT C.cid.. F
95e0: 52 4f 4d 20 20 20 72 65 76 69 73 69 6f 6e 20 52 ROM revision R
95f0: 2c 20 63 73 69 74 65 6d 20 43 49 2c 20 63 68 61 , csitem CI, cha
9600: 6e 67 65 73 65 74 20 43 0a 09 20 20 20 20 57 48 ngeset C.. WH
9610: 45 52 45 20 20 52 2e 72 69 64 20 20 20 49 4e 20 ERE R.rid IN
9620: 24 74 68 65 73 65 74 20 20 20 20 20 2d 2d 20 52 $theset -- R
9630: 65 73 74 72 69 63 74 20 74 6f 20 72 65 76 69 73 estrict to revis
9640: 69 6f 6e 73 20 6f 66 20 69 6e 74 65 72 65 73 74 ions of interest
9650: 0a 09 20 20 20 20 41 4e 44 20 20 20 20 52 2e 63 .. AND R.c
9660: 68 69 6c 64 20 49 53 20 4e 4f 54 20 4e 55 4c 4c hild IS NOT NULL
9670: 20 20 20 20 2d 2d 20 48 61 73 20 70 72 69 6d 61 -- Has prima
9680: 72 79 20 63 68 69 6c 64 0a 20 20 20 20 20 20 20 ry child.
9690: 20 20 20 20 20 41 4e 44 20 20 20 20 43 49 2e 69 AND CI.i
96a0: 69 64 20 3d 20 52 2e 63 68 69 6c 64 20 20 20 20 id = R.child
96b0: 20 20 20 2d 2d 20 53 65 6c 65 63 74 20 61 6c 6c -- Select all
96c0: 20 63 68 61 6e 67 65 73 65 74 73 0a 20 20 20 20 changesets.
96d0: 20 20 20 20 20 20 20 20 41 4e 44 20 20 20 20 43 AND C
96e0: 2e 63 69 64 20 3d 20 43 49 2e 63 69 64 20 20 20 .cid = CI.cid
96f0: 20 20 20 20 20 20 2d 2d 20 63 6f 6e 74 61 69 6e -- contain
9700: 69 6e 67 20 74 68 65 20 70 72 69 6d 61 72 79 20 ing the primary
9710: 63 68 69 6c 64 0a 20 20 20 20 20 20 20 20 20 20 child.
9720: 20 20 41 4e 44 20 20 20 20 43 2e 74 79 70 65 20 AND C.type
9730: 3d 20 30 20 20 20 20 20 20 20 20 20 20 20 20 20 = 0
9740: 2d 2d 20 77 68 69 63 68 20 61 72 65 20 72 65 76 -- which are rev
9750: 69 73 69 6f 6e 20 63 68 61 6e 67 65 73 65 74 73 ision changesets
9760: 0a 20 20 20 20 55 4e 49 4f 4e 0a 20 20 20 20 2d . UNION. -
9770: 2d 20 28 32 29 20 53 65 63 6f 6e 64 61 72 79 20 - (2) Secondary
9780: 28 62 72 61 6e 63 68 29 20 63 68 69 6c 64 72 65 (branch) childre
9790: 6e 0a 09 20 20 20 20 53 45 4c 45 43 54 20 43 2e n.. SELECT C.
97a0: 63 69 64 0a 09 20 20 20 20 46 52 4f 4d 20 20 20 cid.. FROM
97b0: 72 65 76 69 73 69 6f 6e 20 52 2c 20 72 65 76 69 revision R, revi
97c0: 73 69 6f 6e 62 72 61 6e 63 68 63 68 69 6c 64 72 sionbranchchildr
97d0: 65 6e 20 42 2c 20 63 73 69 74 65 6d 20 43 49 2c en B, csitem CI,
97e0: 20 63 68 61 6e 67 65 73 65 74 20 43 0a 09 20 20 changeset C..
97f0: 20 20 57 48 45 52 45 20 20 52 2e 72 69 64 20 20 WHERE R.rid
9800: 20 49 4e 20 24 74 68 65 73 65 74 20 20 20 20 20 IN $theset
9810: 2d 2d 20 52 65 73 74 72 69 63 74 20 74 6f 20 72 -- Restrict to r
9820: 65 76 69 73 69 6f 6e 73 20 6f 66 20 69 6e 74 65 evisions of inte
9830: 72 65 73 74 0a 09 20 20 20 20 41 4e 44 20 20 20 rest.. AND
9840: 20 52 2e 72 69 64 20 3d 20 42 2e 72 69 64 20 20 R.rid = B.rid
9850: 20 20 20 20 20 20 20 20 2d 2d 20 53 65 6c 65 63 -- Selec
9860: 74 20 73 75 62 73 65 74 20 6f 66 20 62 72 61 6e t subset of bran
9870: 63 68 20 63 68 69 6c 64 72 65 6e 0a 20 20 20 20 ch children.
9880: 20 20 20 20 20 20 20 20 41 4e 44 20 20 20 20 43 AND C
9890: 49 2e 69 69 64 20 3d 20 42 2e 62 72 69 64 20 20 I.iid = B.brid
98a0: 20 20 20 20 20 20 2d 2d 20 53 65 6c 65 63 74 20 -- Select
98b0: 61 6c 6c 20 63 68 61 6e 67 65 73 65 74 73 0a 20 all changesets.
98c0: 20 20 20 20 20 20 20 20 20 20 20 41 4e 44 20 20 AND
98d0: 20 20 43 2e 63 69 64 20 3d 20 43 49 2e 63 69 64 C.cid = CI.cid
98e0: 09 20 20 2d 2d 20 63 6f 6e 74 61 69 6e 69 6e 67 . -- containing
98f0: 20 74 68 65 20 62 72 61 6e 63 68 0a 20 20 20 20 the branch.
9900: 20 20 20 20 20 20 20 20 41 4e 44 20 20 20 20 43 AND C
9910: 2e 74 79 70 65 20 3d 20 30 09 09 20 20 2d 2d 20 .type = 0.. --
9920: 77 68 69 63 68 20 61 72 65 20 72 65 76 69 73 69 which are revisi
9930: 6f 6e 20 63 68 61 6e 67 65 73 65 74 73 0a 20 20 on changesets.
9940: 20 20 55 4e 49 4f 4e 0a 20 20 20 20 2d 2d 20 28 UNION. -- (
9950: 34 29 20 43 68 69 6c 64 20 6f 66 20 74 72 75 6e 4) Child of trun
9960: 6b 20 72 6f 6f 74 20 73 75 63 63 65 73 73 6f 72 k root successor
9970: 20 6f 66 20 6c 61 73 74 20 4e 54 44 42 20 6f 6e of last NTDB on
9980: 20 74 72 75 6e 6b 2e 0a 09 20 20 20 20 53 45 4c trunk... SEL
9990: 45 43 54 20 43 2e 63 69 64 0a 09 20 20 20 20 46 ECT C.cid.. F
99a0: 52 4f 4d 20 20 20 72 65 76 69 73 69 6f 6e 20 52 ROM revision R
99b0: 2c 20 72 65 76 69 73 69 6f 6e 20 52 41 2c 20 63 , revision RA, c
99c0: 73 69 74 65 6d 20 43 49 2c 20 63 68 61 6e 67 65 sitem CI, change
99d0: 73 65 74 20 43 0a 09 20 20 20 20 57 48 45 52 45 set C.. WHERE
99e0: 20 20 52 2e 72 69 64 20 20 20 49 4e 20 24 74 68 R.rid IN $th
99f0: 65 73 65 74 20 20 20 20 20 20 2d 2d 20 52 65 73 eset -- Res
9a00: 74 72 69 63 74 20 74 6f 20 72 65 76 69 73 69 6f trict to revisio
9a10: 6e 73 20 6f 66 20 69 6e 74 65 72 65 73 74 0a 09 ns of interest..
9a20: 20 20 20 20 41 4e 44 20 20 20 20 52 2e 69 73 64 AND R.isd
9a30: 65 66 61 75 6c 74 20 20 20 20 20 20 20 20 20 20 efault
9a40: 20 20 20 2d 2d 20 52 65 73 74 72 69 63 74 20 74 -- Restrict t
9a50: 6f 20 4e 54 44 42 0a 09 20 20 20 20 41 4e 44 20 o NTDB.. AND
9a60: 20 20 20 52 2e 64 62 63 68 69 6c 64 20 49 53 20 R.dbchild IS
9a70: 4e 4f 54 20 4e 55 4c 4c 20 20 20 2d 2d 20 61 6e NOT NULL -- an
9a80: 64 20 6c 61 73 74 20 4e 54 44 42 20 62 65 6c 6f d last NTDB belo
9a90: 6e 67 69 6e 67 20 74 6f 20 74 72 75 6e 6b 0a 09 nging to trunk..
9aa0: 20 20 20 20 41 4e 44 20 20 20 20 52 41 2e 72 69 AND RA.ri
9ab0: 64 20 3d 20 52 2e 64 62 63 68 69 6c 64 20 20 20 d = R.dbchild
9ac0: 20 20 20 2d 2d 20 47 6f 20 64 69 72 65 63 74 6c -- Go directl
9ad0: 79 20 74 6f 20 74 72 75 6e 6b 20 72 6f 6f 74 0a y to trunk root.
9ae0: 09 20 20 20 20 41 4e 44 20 20 20 20 52 41 2e 63 . AND RA.c
9af0: 68 69 6c 64 20 49 53 20 4e 4f 54 20 4e 55 4c 4c hild IS NOT NULL
9b00: 20 20 20 20 2d 2d 20 48 61 73 20 70 72 69 6d 61 -- Has prima
9b10: 72 79 20 63 68 69 6c 64 2e 0a 20 20 20 20 20 20 ry child..
9b20: 20 20 20 20 20 20 41 4e 44 20 20 20 20 43 49 2e AND CI.
9b30: 69 69 64 20 3d 20 52 41 2e 63 68 69 6c 64 20 20 iid = RA.child
9b40: 20 20 20 20 20 2d 2d 20 53 65 6c 65 63 74 20 61 -- Select a
9b50: 6c 6c 20 63 68 61 6e 67 65 73 65 74 73 0a 20 20 ll changesets.
9b60: 20 20 20 20 20 20 20 20 20 20 41 4e 44 20 20 20 AND
9b70: 20 43 2e 63 69 64 20 3d 20 43 49 2e 63 69 64 09 C.cid = CI.cid.
9b80: 20 20 20 2d 2d 20 63 6f 6e 74 61 69 6e 69 6e 67 -- containing
9b90: 20 74 68 65 20 70 72 69 6d 61 72 79 20 63 68 69 the primary chi
9ba0: 6c 64 0a 20 20 20 20 20 20 20 20 20 20 20 20 41 ld. A
9bb0: 4e 44 20 20 20 20 43 2e 74 79 70 65 20 3d 20 30 ND C.type = 0
9bc0: 09 09 20 20 20 2d 2d 20 77 68 69 63 68 20 61 72 .. -- which ar
9bd0: 65 20 72 65 76 69 73 69 6f 6e 20 63 68 61 6e 67 e revision chang
9be0: 65 73 65 74 73 0a 20 20 20 20 55 4e 49 4f 4e 0a esets. UNION.
9bf0: 09 20 20 20 20 53 45 4c 45 43 54 20 43 2e 63 69 . SELECT C.ci
9c00: 64 0a 09 20 20 20 20 46 52 4f 4d 20 20 20 72 65 d.. FROM re
9c10: 76 69 73 69 6f 6e 20 52 2c 20 74 61 67 20 54 2c vision R, tag T,
9c20: 20 63 73 69 74 65 6d 20 43 49 2c 20 63 68 61 6e csitem CI, chan
9c30: 67 65 73 65 74 20 43 0a 09 20 20 20 20 57 48 45 geset C.. WHE
9c40: 52 45 20 20 52 2e 72 69 64 20 69 6e 20 24 74 68 RE R.rid in $th
9c50: 65 73 65 74 20 20 20 20 20 20 20 20 2d 2d 20 52 eset -- R
9c60: 65 73 74 72 69 63 74 20 74 6f 20 72 65 76 69 73 estrict to revis
9c70: 69 6f 6e 73 20 6f 66 20 69 6e 74 65 72 65 73 74 ions of interest
9c80: 0a 09 20 20 20 20 41 4e 44 20 20 20 20 54 2e 72 .. AND T.r
9c90: 65 76 20 3d 20 52 2e 72 69 64 09 20 20 20 2d 2d ev = R.rid. --
9ca0: 20 53 65 6c 65 63 74 20 74 61 67 73 20 61 74 74 Select tags att
9cb0: 61 63 68 65 64 20 74 6f 20 74 68 65 6d 0a 20 20 ached to them.
9cc0: 20 20 20 20 20 20 20 20 20 20 41 4e 44 20 20 20 AND
9cd0: 20 43 49 2e 69 69 64 20 3d 20 54 2e 74 69 64 20 CI.iid = T.tid
9ce0: 20 20 20 20 20 20 20 20 20 2d 2d 20 53 65 6c 65 -- Sele
9cf0: 63 74 20 61 6c 6c 20 63 68 61 6e 67 65 73 65 74 ct all changeset
9d00: 73 0a 20 20 20 20 20 20 20 20 20 20 20 20 41 4e s. AN
9d10: 44 20 20 20 20 43 2e 63 69 64 20 3d 20 43 49 2e D C.cid = CI.
9d20: 63 69 64 09 20 20 20 2d 2d 20 63 6f 6e 74 61 69 cid. -- contai
9d30: 6e 69 6e 67 20 74 68 65 20 74 61 67 73 0a 20 20 ning the tags.
9d40: 20 20 20 20 20 20 20 20 20 20 41 4e 44 20 20 20 AND
9d50: 20 43 2e 74 79 70 65 20 3d 20 31 09 09 20 20 20 C.type = 1..
9d60: 2d 2d 20 77 68 69 63 68 20 61 72 65 20 74 61 67 -- which are tag
9d70: 20 63 68 61 6e 67 65 73 65 74 73 0a 20 20 20 20 changesets.
9d80: 55 4e 49 4f 4e 0a 09 20 20 20 20 53 45 4c 45 43 UNION.. SELEC
9d90: 54 20 43 2e 63 69 64 0a 09 20 20 20 20 46 52 4f T C.cid.. FRO
9da0: 4d 20 20 20 72 65 76 69 73 69 6f 6e 20 52 2c 20 M revision R,
9db0: 62 72 61 6e 63 68 20 42 2c 20 63 73 69 74 65 6d branch B, csitem
9dc0: 20 43 49 2c 20 63 68 61 6e 67 65 73 65 74 20 43 CI, changeset C
9dd0: 0a 09 20 20 20 20 57 48 45 52 45 20 20 52 2e 72 .. WHERE R.r
9de0: 69 64 20 69 6e 20 24 74 68 65 73 65 74 20 20 20 id in $theset
9df0: 20 20 20 20 20 2d 2d 20 52 65 73 74 72 69 63 74 -- Restrict
9e00: 20 74 6f 20 72 65 76 69 73 69 6f 6e 73 20 6f 66 to revisions of
9e10: 20 69 6e 74 65 72 65 73 74 0a 09 20 20 20 20 41 interest.. A
9e20: 4e 44 20 20 20 20 42 2e 72 6f 6f 74 20 3d 20 52 ND B.root = R
9e30: 2e 72 69 64 09 20 20 20 2d 2d 20 53 65 6c 65 63 .rid. -- Selec
9e40: 74 20 62 72 61 6e 63 68 65 73 20 61 74 74 61 63 t branches attac
9e50: 68 65 64 20 74 6f 20 74 68 65 6d 0a 20 20 20 20 hed to them.
9e60: 20 20 20 20 20 20 20 20 41 4e 44 20 20 20 20 43 AND C
9e70: 49 2e 69 69 64 20 3d 20 42 2e 62 69 64 20 20 20 I.iid = B.bid
9e80: 20 20 20 20 20 20 20 2d 2d 20 53 65 6c 65 63 74 -- Select
9e90: 20 61 6c 6c 20 63 68 61 6e 67 65 73 65 74 73 0a all changesets.
9ea0: 20 20 20 20 20 20 20 20 20 20 20 20 41 4e 44 20 AND
9eb0: 20 20 20 43 2e 63 69 64 20 3d 20 43 49 2e 63 69 C.cid = CI.ci
9ec0: 64 09 20 20 20 2d 2d 20 63 6f 6e 74 61 69 6e 69 d. -- containi
9ed0: 6e 67 20 74 68 65 20 62 72 61 6e 63 68 65 73 0a ng the branches.
9ee0: 20 20 20 20 20 20 20 20 20 20 20 20 41 4e 44 20 AND
9ef0: 20 20 20 43 2e 74 79 70 65 20 3d 20 32 09 09 20 C.type = 2..
9f00: 20 20 2d 2d 20 77 68 69 63 68 20 61 72 65 20 62 -- which are b
9f10: 72 61 6e 63 68 20 63 68 61 6e 67 65 73 65 74 73 ranch changesets
9f20: 0a 09 7d 5d 5d 0a 20 20 20 20 7d 0a 7d 0a 0a 23 ..}]]. }.}..#
9f30: 20 23 20 23 23 20 23 23 23 20 23 23 23 23 23 20 # ## ### #####
9f40: 23 23 23 23 23 23 23 23 20 23 23 23 23 23 23 23 ######## #######
9f50: 23 23 23 23 23 23 20 23 23 23 23 23 23 23 23 23 ###### #########
9f60: 23 23 23 23 23 23 23 23 23 23 23 23 0a 23 23 20 ############.##
9f70: 48 65 6c 70 65 72 20 73 69 6e 67 6c 65 74 6f 6e Helper singleton
9f80: 2e 20 43 6f 6d 6d 61 6e 64 73 20 66 6f 72 20 74 . Commands for t
9f90: 61 67 20 73 79 6d 62 6f 6c 20 63 68 61 6e 67 65 ag symbol change
9fa0: 73 65 74 73 2e 0a 0a 73 6e 69 74 3a 3a 74 79 70 sets...snit::typ
9fb0: 65 20 3a 3a 76 63 3a 3a 66 6f 73 73 69 6c 3a 3a e ::vc::fossil::
9fc0: 69 6d 70 6f 72 74 3a 3a 63 76 73 3a 3a 70 72 6f import::cvs::pro
9fd0: 6a 65 63 74 3a 3a 72 65 76 3a 3a 73 79 6d 3a 3a ject::rev::sym::
9fe0: 74 61 67 20 7b 0a 20 20 20 20 74 79 70 65 6d 65 tag {. typeme
9ff0: 74 68 6f 64 20 62 79 72 65 76 69 73 69 6f 6e 20 thod byrevision
a000: 7b 7d 20 7b 20 72 65 74 75 72 6e 20 30 20 7d 0a {} { return 0 }.
a010: 20 20 20 20 74 79 70 65 6d 65 74 68 6f 64 20 62 typemethod b
a020: 79 73 79 6d 62 6f 6c 20 20 20 7b 7d 20 7b 20 72 ysymbol {} { r
a030: 65 74 75 72 6e 20 31 20 7d 0a 20 20 20 20 74 79 eturn 1 }. ty
a040: 70 65 6d 65 74 68 6f 64 20 69 73 74 61 67 20 20 pemethod istag
a050: 20 20 20 20 7b 7d 20 7b 20 72 65 74 75 72 6e 20 {} { return
a060: 31 20 7d 0a 20 20 20 20 74 79 70 65 6d 65 74 68 1 }. typemeth
a070: 6f 64 20 69 73 62 72 61 6e 63 68 20 20 20 7b 7d od isbranch {}
a080: 20 7b 20 72 65 74 75 72 6e 20 30 20 7d 0a 0a 20 { return 0 }..
a090: 20 20 20 74 79 70 65 6d 65 74 68 6f 64 20 73 74 typemethod st
a0a0: 72 20 7b 74 61 67 7d 20 7b 0a 09 73 74 72 75 63 r {tag} {..struc
a0b0: 74 3a 3a 6c 69 73 74 20 61 73 73 69 67 6e 20 5b t::list assign [
a0c0: 73 74 61 74 65 20 72 75 6e 20 7b 0a 09 20 20 20 state run {..
a0d0: 20 53 45 4c 45 43 54 20 53 2e 6e 61 6d 65 2c 20 SELECT S.name,
a0e0: 46 2e 6e 61 6d 65 2c 20 50 2e 6e 61 6d 65 0a 09 F.name, P.name..
a0f0: 20 20 20 20 46 52 4f 4d 20 20 20 74 61 67 20 54 FROM tag T
a100: 2c 20 73 79 6d 62 6f 6c 20 53 2c 20 66 69 6c 65 , symbol S, file
a110: 20 46 2c 20 70 72 6f 6a 65 63 74 20 50 0a 09 20 F, project P..
a120: 20 20 20 57 48 45 52 45 20 20 54 2e 74 69 64 20 WHERE T.tid
a130: 3d 20 24 74 61 67 20 20 20 2d 2d 20 46 69 6e 64 = $tag -- Find
a140: 20 73 70 65 63 69 66 69 65 64 20 74 61 67 0a 09 specified tag..
a150: 20 20 20 20 41 4e 44 20 20 20 20 46 2e 66 69 64 AND F.fid
a160: 20 3d 20 54 2e 66 69 64 20 20 2d 2d 20 47 65 74 = T.fid -- Get
a170: 20 66 69 6c 65 20 6f 66 20 74 61 67 0a 09 20 20 file of tag..
a180: 20 20 41 4e 44 20 20 20 20 50 2e 70 69 64 20 3d AND P.pid =
a190: 20 46 2e 70 69 64 20 20 2d 2d 20 47 65 74 20 70 F.pid -- Get p
a1a0: 72 6f 6a 65 63 74 20 6f 66 20 66 69 6c 65 0a 09 roject of file..
a1b0: 20 20 20 20 41 4e 44 20 20 20 20 53 2e 73 69 64 AND S.sid
a1c0: 20 3d 20 54 2e 73 69 64 20 20 2d 2d 20 47 65 74 = T.sid -- Get
a1d0: 20 73 79 6d 62 6f 6c 20 6f 66 20 74 61 67 0a 09 symbol of tag..
a1e0: 7d 5d 20 73 6e 61 6d 65 20 66 6e 61 6d 65 20 70 }] sname fname p
a1f0: 6e 61 6d 65 0a 09 72 65 74 75 72 6e 20 22 24 70 name..return "$p
a200: 6e 61 6d 65 2f 54 27 24 7b 73 6e 61 6d 65 7d 27 name/T'${sname}'
a210: 3a 3a 24 66 6e 61 6d 65 22 0a 20 20 20 20 7d 0a ::$fname". }.
a220: 0a 20 20 20 20 23 20 72 65 73 75 6c 74 20 3d 20 . # result =
a230: 6c 69 73 74 20 28 6d 69 6e 74 69 6d 65 2c 20 6d list (mintime, m
a240: 61 78 74 69 6d 65 29 0a 20 20 20 20 74 79 70 65 axtime). type
a250: 6d 65 74 68 6f 64 20 74 69 6d 65 72 61 6e 67 65 method timerange
a260: 20 7b 74 61 67 73 7d 20 7b 0a 09 23 20 54 68 65 {tags} {..# The
a270: 20 72 61 6e 67 65 20 69 73 20 64 65 66 69 6e 65 range is define
a280: 64 20 61 73 20 74 68 65 20 72 61 6e 67 65 20 6f d as the range o
a290: 66 20 74 68 65 20 72 65 76 69 73 69 6f 6e 73 20 f the revisions
a2a0: 74 68 65 20 74 61 67 73 0a 09 23 20 61 72 65 20 the tags..# are
a2b0: 61 74 74 61 63 68 65 64 20 74 6f 2e 0a 0a 09 73 attached to....s
a2c0: 65 74 20 74 68 65 73 65 74 20 28 27 5b 6a 6f 69 et theset ('[joi
a2d0: 6e 20 24 74 61 67 73 20 7b 27 2c 27 7d 5d 27 29 n $tags {','}]')
a2e0: 0a 09 72 65 74 75 72 6e 20 5b 73 74 61 74 65 20 ..return [state
a2f0: 72 75 6e 20 5b 73 75 62 73 74 20 2d 6e 6f 63 6f run [subst -noco
a300: 6d 6d 61 6e 64 73 20 2d 6e 6f 62 61 63 6b 73 6c mmands -nobacksl
a310: 61 73 68 65 73 20 7b 0a 09 20 20 20 20 53 45 4c ashes {.. SEL
a320: 45 43 54 20 4d 49 4e 28 52 2e 64 61 74 65 29 2c ECT MIN(R.date),
a330: 20 4d 41 58 28 52 2e 64 61 74 65 29 0a 09 20 20 MAX(R.date)..
a340: 20 20 46 52 4f 4d 20 20 20 74 61 67 20 54 2c 20 FROM tag T,
a350: 72 65 76 69 73 69 6f 6e 20 52 0a 09 20 20 20 20 revision R..
a360: 57 48 45 52 45 20 20 54 2e 74 69 64 20 49 4e 20 WHERE T.tid IN
a370: 24 74 68 65 73 65 74 20 20 2d 2d 20 52 65 73 74 $theset -- Rest
a380: 72 69 63 74 20 74 6f 20 74 61 67 73 20 6f 66 20 rict to tags of
a390: 69 6e 74 65 72 65 73 74 0a 20 20 20 20 20 20 20 interest.
a3a0: 20 20 20 20 20 41 4e 44 20 20 20 20 52 2e 72 69 AND R.ri
a3b0: 64 20 3d 20 54 2e 72 65 76 20 20 20 20 20 2d 2d d = T.rev --
a3c0: 20 53 65 6c 65 63 74 20 74 61 67 20 70 61 72 65 Select tag pare
a3d0: 6e 74 20 72 65 76 69 73 69 6f 6e 73 0a 09 7d 5d nt revisions..}]
a3e0: 5d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 23 20 76 ]. }.. # v
a3f0: 61 72 28 64 76 29 20 3d 20 64 69 63 74 20 28 69 ar(dv) = dict (i
a400: 74 65 6d 20 2d 3e 20 6c 69 73 74 20 28 69 74 65 tem -> list (ite
a410: 6d 29 29 2c 20 69 74 65 6d 20 20 3d 20 6c 69 73 m)), item = lis
a420: 74 20 28 74 79 70 65 20 69 64 29 0a 20 20 20 20 t (type id).
a430: 74 79 70 65 6d 65 74 68 6f 64 20 73 75 63 63 65 typemethod succe
a440: 73 73 6f 72 73 20 7b 64 76 20 74 61 67 73 7d 20 ssors {dv tags}
a450: 7b 0a 09 23 20 54 61 67 73 20 68 61 76 65 20 6e {..# Tags have n
a460: 6f 20 73 75 63 63 65 73 73 6f 72 73 2e 0a 09 72 o successors...r
a470: 65 74 75 72 6e 0a 20 20 20 20 7d 0a 0a 20 20 20 eturn. }..
a480: 20 23 20 72 65 73 75 6c 74 20 3d 20 34 2d 6c 69 # result = 4-li
a490: 73 74 20 28 69 74 65 6d 74 79 70 65 20 69 74 65 st (itemtype ite
a4a0: 6d 69 64 20 6e 65 78 74 69 74 65 6d 74 79 70 65 mid nextitemtype
a4b0: 20 6e 65 78 74 69 74 65 6d 69 64 20 2e 2e 2e 29 nextitemid ...)
a4c0: 0a 20 20 20 20 74 79 70 65 6d 65 74 68 6f 64 20 . typemethod
a4d0: 6c 6f 6f 70 73 20 7b 74 61 67 73 7d 20 7b 0a 09 loops {tags} {..
a4e0: 23 20 54 61 67 73 20 68 61 76 65 20 6e 6f 20 73 # Tags have no s
a4f0: 75 63 63 65 73 73 6f 72 73 2c 20 74 68 65 72 65 uccessors, there
a500: 66 6f 72 65 20 63 61 6e 6e 6f 74 20 63 61 75 73 fore cannot caus
a510: 65 20 6c 6f 6f 70 73 0a 09 72 65 74 75 72 6e 20 e loops..return
a520: 7b 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 23 20 {}. }.. #
a530: 72 65 73 75 6c 74 20 3d 20 6c 69 73 74 20 28 63 result = list (c
a540: 68 61 6e 67 65 73 65 74 2d 69 64 29 0a 20 20 20 hangeset-id).
a550: 20 74 79 70 65 6d 65 74 68 6f 64 20 63 73 5f 73 typemethod cs_s
a560: 75 63 63 65 73 73 6f 72 73 20 7b 74 61 67 73 7d uccessors {tags}
a570: 20 7b 0a 09 23 20 54 61 67 73 20 68 61 76 65 20 {..# Tags have
a580: 6e 6f 20 73 75 63 63 65 73 73 6f 72 73 2e 0a 09 no successors...
a590: 72 65 74 75 72 6e 0a 20 20 20 20 7d 0a 7d 0a 0a return. }.}..
a5a0: 23 20 23 20 23 23 20 23 23 23 20 23 23 23 23 23 # # ## ### #####
a5b0: 20 23 23 23 23 23 23 23 23 20 23 23 23 23 23 23 ######## ######
a5c0: 23 23 23 23 23 23 23 20 23 23 23 23 23 23 23 23 ####### ########
a5d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 0a 23 23 #############.##
a5e0: 20 48 65 6c 70 65 72 20 73 69 6e 67 6c 65 74 6f Helper singleto
a5f0: 6e 2e 20 43 6f 6d 6d 61 6e 64 73 20 66 6f 72 20 n. Commands for
a600: 62 72 61 6e 63 68 20 73 79 6d 62 6f 6c 20 63 68 branch symbol ch
a610: 61 6e 67 65 73 65 74 73 2e 0a 0a 73 6e 69 74 3a angesets...snit:
a620: 3a 74 79 70 65 20 3a 3a 76 63 3a 3a 66 6f 73 73 :type ::vc::foss
a630: 69 6c 3a 3a 69 6d 70 6f 72 74 3a 3a 63 76 73 3a il::import::cvs:
a640: 3a 70 72 6f 6a 65 63 74 3a 3a 72 65 76 3a 3a 73 :project::rev::s
a650: 79 6d 3a 3a 62 72 61 6e 63 68 20 7b 0a 20 20 20 ym::branch {.
a660: 20 74 79 70 65 6d 65 74 68 6f 64 20 62 79 72 65 typemethod byre
a670: 76 69 73 69 6f 6e 20 7b 7d 20 7b 20 72 65 74 75 vision {} { retu
a680: 72 6e 20 30 20 7d 0a 20 20 20 20 74 79 70 65 6d rn 0 }. typem
a690: 65 74 68 6f 64 20 62 79 73 79 6d 62 6f 6c 20 20 ethod bysymbol
a6a0: 20 7b 7d 20 7b 20 72 65 74 75 72 6e 20 31 20 7d {} { return 1 }
a6b0: 0a 20 20 20 20 74 79 70 65 6d 65 74 68 6f 64 20 . typemethod
a6c0: 69 73 74 61 67 20 20 20 20 20 20 7b 7d 20 7b 20 istag {} {
a6d0: 72 65 74 75 72 6e 20 30 20 7d 0a 20 20 20 20 74 return 0 }. t
a6e0: 79 70 65 6d 65 74 68 6f 64 20 69 73 62 72 61 6e ypemethod isbran
a6f0: 63 68 20 20 20 7b 7d 20 7b 20 72 65 74 75 72 6e ch {} { return
a700: 20 31 20 7d 0a 0a 20 20 20 20 74 79 70 65 6d 65 1 }.. typeme
a710: 74 68 6f 64 20 73 74 72 20 7b 62 72 61 6e 63 68 thod str {branch
a720: 7d 20 7b 0a 09 73 74 72 75 63 74 3a 3a 6c 69 73 } {..struct::lis
a730: 74 20 61 73 73 69 67 6e 20 5b 73 74 61 74 65 20 t assign [state
a740: 72 75 6e 20 7b 0a 09 20 20 20 20 53 45 4c 45 43 run {.. SELEC
a750: 54 20 53 2e 6e 61 6d 65 2c 20 46 2e 6e 61 6d 65 T S.name, F.name
a760: 2c 20 50 2e 6e 61 6d 65 0a 09 20 20 20 20 46 52 , P.name.. FR
a770: 4f 4d 20 20 20 62 72 61 6e 63 68 20 42 2c 20 73 OM branch B, s
a780: 79 6d 62 6f 6c 20 53 2c 20 66 69 6c 65 20 46 2c ymbol S, file F,
a790: 20 70 72 6f 6a 65 63 74 20 50 0a 09 20 20 20 20 project P..
a7a0: 57 48 45 52 45 20 20 42 2e 62 69 64 20 3d 20 24 WHERE B.bid = $
a7b0: 62 72 61 6e 63 68 20 20 2d 2d 20 46 69 6e 64 20 branch -- Find
a7c0: 73 70 65 63 69 66 69 65 64 20 62 72 61 6e 63 68 specified branch
a7d0: 0a 09 20 20 20 20 41 4e 44 20 20 20 20 46 2e 66 .. AND F.f
a7e0: 69 64 20 3d 20 42 2e 66 69 64 20 20 20 20 2d 2d id = B.fid --
a7f0: 20 47 65 74 20 66 69 6c 65 20 6f 66 20 62 72 61 Get file of bra
a800: 6e 63 68 0a 09 20 20 20 20 41 4e 44 20 20 20 20 nch.. AND
a810: 50 2e 70 69 64 20 3d 20 46 2e 70 69 64 20 20 20 P.pid = F.pid
a820: 20 2d 2d 20 47 65 74 20 70 72 6f 6a 65 63 74 20 -- Get project
a830: 6f 66 20 66 69 6c 65 0a 09 20 20 20 20 41 4e 44 of file.. AND
a840: 20 20 20 20 53 2e 73 69 64 20 3d 20 42 2e 73 69 S.sid = B.si
a850: 64 20 20 20 20 2d 2d 20 47 65 74 20 73 79 6d 62 d -- Get symb
a860: 6f 6c 20 6f 66 20 62 72 61 6e 63 68 0a 09 7d 5d ol of branch..}]
a870: 20 73 6e 61 6d 65 20 66 6e 61 6d 65 20 70 6e 61 sname fname pna
a880: 6d 65 0a 09 72 65 74 75 72 6e 20 22 24 70 6e 61 me..return "$pna
a890: 6d 65 2f 42 27 24 7b 73 6e 61 6d 65 7d 27 3a 3a me/B'${sname}'::
a8a0: 24 66 6e 61 6d 65 22 0a 20 20 20 20 7d 0a 0a 20 $fname". }..
a8b0: 20 20 20 23 20 72 65 73 75 6c 74 20 3d 20 6c 69 # result = li
a8c0: 73 74 20 28 6d 69 6e 74 69 6d 65 2c 20 6d 61 78 st (mintime, max
a8d0: 74 69 6d 65 29 0a 20 20 20 20 74 79 70 65 6d 65 time). typeme
a8e0: 74 68 6f 64 20 74 69 6d 65 72 61 6e 67 65 20 7b thod timerange {
a8f0: 62 72 61 6e 63 68 65 73 7d 20 7b 0a 09 23 20 54 branches} {..# T
a900: 68 65 20 72 61 6e 67 65 20 6f 66 20 61 20 62 72 he range of a br
a910: 61 6e 63 68 20 69 73 20 64 65 66 69 6e 65 64 20 anch is defined
a920: 61 73 20 74 68 65 20 72 61 6e 67 65 20 6f 66 20 as the range of
a930: 74 68 65 0a 09 23 20 72 65 76 69 73 69 6f 6e 73 the..# revisions
a940: 20 74 68 65 20 62 72 61 6e 63 68 65 73 20 61 72 the branches ar
a950: 65 20 73 70 61 77 6e 65 64 20 62 79 2e 20 4e 4f e spawned by. NO
a960: 54 45 20 68 6f 77 65 76 65 72 20 74 68 61 74 20 TE however that
a970: 74 68 65 0a 09 23 20 62 72 61 6e 63 68 65 73 20 the..# branches
a980: 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 68 20 associated with
a990: 61 20 64 65 74 61 63 68 65 64 20 4e 54 44 42 20 a detached NTDB
a9a0: 77 69 6c 6c 20 68 61 76 65 20 6e 6f 20 72 6f 6f will have no roo
a9b0: 74 0a 09 23 20 73 70 61 77 6e 69 6e 67 20 74 68 t..# spawning th
a9c0: 65 6d 2c 20 68 65 6e 63 65 20 74 68 65 79 20 68 em, hence they h
a9d0: 61 76 65 20 6e 6f 20 72 65 61 6c 20 74 69 6d 65 ave no real time
a9e0: 72 61 6e 67 65 20 61 6e 79 0a 09 23 20 6c 6f 6e range any..# lon
a9f0: 67 65 72 2e 20 42 79 20 75 73 69 6e 67 20 30 20 ger. By using 0
aa00: 77 65 20 70 75 74 20 74 68 65 6d 20 69 6e 20 66 we put them in f
aa10: 72 6f 6e 74 20 6f 66 20 65 76 65 72 79 74 68 69 ront of everythi
aa20: 6e 67 20 65 6c 73 65 2c 0a 09 23 20 61 73 20 74 ng else,..# as t
aa30: 68 65 79 20 6c 6f 67 69 63 61 6c 6c 79 20 61 72 hey logically ar
aa40: 65 2e 0a 0a 09 73 65 74 20 74 68 65 73 65 74 20 e....set theset
aa50: 28 27 5b 6a 6f 69 6e 20 24 62 72 61 6e 63 68 65 ('[join $branche
aa60: 73 20 7b 27 2c 27 7d 5d 27 29 0a 09 72 65 74 75 s {','}]')..retu
aa70: 72 6e 20 5b 73 74 61 74 65 20 72 75 6e 20 5b 73 rn [state run [s
aa80: 75 62 73 74 20 2d 6e 6f 63 6f 6d 6d 61 6e 64 73 ubst -nocommands
aa90: 20 2d 6e 6f 62 61 63 6b 73 6c 61 73 68 65 73 20 -nobackslashes
aaa0: 7b 0a 09 20 20 20 20 53 45 4c 45 43 54 20 49 46 {.. SELECT IF
aab0: 4e 55 4c 4c 28 4d 49 4e 28 52 2e 64 61 74 65 29 NULL(MIN(R.date)
aac0: 2c 30 29 2c 20 49 46 4e 55 4c 4c 28 4d 41 58 28 ,0), IFNULL(MAX(
aad0: 52 2e 64 61 74 65 29 2c 30 29 0a 09 20 20 20 20 R.date),0)..
aae0: 46 52 4f 4d 20 20 62 72 61 6e 63 68 20 42 2c 20 FROM branch B,
aaf0: 72 65 76 69 73 69 6f 6e 20 52 0a 09 20 20 20 20 revision R..
ab00: 57 48 45 52 45 20 42 2e 62 69 64 20 49 4e 20 24 WHERE B.bid IN $
ab10: 74 68 65 73 65 74 20 20 20 2d 2d 20 52 65 73 74 theset -- Rest
ab20: 72 69 63 74 20 74 6f 20 62 72 61 6e 63 68 65 73 rict to branches
ab30: 20 6f 66 20 69 6e 74 65 72 65 73 74 0a 20 20 20 of interest.
ab40: 20 20 20 20 20 20 20 20 20 41 4e 44 20 20 20 52 AND R
ab50: 2e 72 69 64 20 3d 20 42 2e 72 6f 6f 74 20 20 20 .rid = B.root
ab60: 20 20 2d 2d 20 53 65 6c 65 63 74 20 62 72 61 6e -- Select bran
ab70: 63 68 20 70 61 72 65 6e 74 20 72 65 76 69 73 69 ch parent revisi
ab80: 6f 6e 73 0a 09 7d 5d 5d 0a 20 20 20 20 7d 0a 0a ons..}]]. }..
ab90: 20 20 20 20 23 20 72 65 73 75 6c 74 20 3d 20 34 # result = 4
aba0: 2d 6c 69 73 74 20 28 69 74 65 6d 74 79 70 65 20 -list (itemtype
abb0: 69 74 65 6d 69 64 20 6e 65 78 74 69 74 65 6d 74 itemid nextitemt
abc0: 79 70 65 20 6e 65 78 74 69 74 65 6d 69 64 20 2e ype nextitemid .
abd0: 2e 2e 29 0a 20 20 20 20 74 79 70 65 6d 65 74 68 ..). typemeth
abe0: 6f 64 20 6c 6f 6f 70 73 20 7b 62 72 61 6e 63 68 od loops {branch
abf0: 65 73 7d 20 7b 0a 09 23 20 4e 6f 74 65 3a 20 52 es} {..# Note: R
ac00: 65 76 69 73 69 6f 6e 73 20 61 6e 64 20 74 61 67 evisions and tag
ac10: 73 20 63 61 6e 6e 6f 74 20 63 61 75 73 65 20 74 s cannot cause t
ac20: 68 65 20 6c 6f 6f 70 2e 20 42 65 69 6e 67 20 6f he loop. Being o
ac30: 66 20 61 0a 09 23 20 66 75 6e 64 61 6d 65 6e 74 f a..# fundament
ac40: 61 6c 6c 79 20 64 69 66 66 65 72 65 6e 74 20 74 ally different t
ac50: 79 70 65 20 74 68 65 79 20 63 61 6e 6e 6f 74 20 ype they cannot
ac60: 62 65 20 69 6e 20 74 68 65 20 69 6e 63 6f 6d 69 be in the incomi
ac70: 6e 67 0a 09 23 20 73 65 74 20 6f 66 20 69 64 73 ng..# set of ids
ac80: 2e 0a 0a 09 73 65 74 20 74 68 65 73 65 74 20 28 ....set theset (
ac90: 27 5b 6a 6f 69 6e 20 24 62 72 61 6e 63 68 65 73 '[join $branches
aca0: 20 7b 27 2c 27 7d 5d 27 29 0a 09 72 65 74 75 72 {','}]')..retur
acb0: 6e 20 5b 73 74 61 74 65 20 72 75 6e 20 5b 73 75 n [state run [su
acc0: 62 73 74 20 2d 6e 6f 63 6f 6d 6d 61 6e 64 73 20 bst -nocommands
acd0: 2d 6e 6f 62 61 63 6b 73 6c 61 73 68 65 73 20 7b -nobackslashes {
ace0: 0a 09 20 20 20 20 53 45 4c 45 43 54 20 42 2e 62 .. SELECT B.b
acf0: 69 64 2c 20 42 58 2e 62 69 64 0a 09 20 20 20 20 id, BX.bid..
ad00: 46 52 4f 4d 20 20 20 62 72 61 6e 63 68 20 42 2c FROM branch B,
ad10: 20 70 72 65 66 65 72 65 64 70 61 72 65 6e 74 20 preferedparent
ad20: 50 2c 20 62 72 61 6e 63 68 20 42 58 0a 09 20 20 P, branch BX..
ad30: 20 20 57 48 45 52 45 20 20 42 2e 62 69 64 20 49 WHERE B.bid I
ad40: 4e 20 24 74 68 65 73 65 74 20 20 20 2d 2d 20 52 N $theset -- R
ad50: 65 73 74 72 69 63 74 20 74 6f 20 62 72 61 6e 63 estrict to branc
ad60: 68 65 73 20 6f 66 20 69 6e 74 65 72 65 73 74 0a hes of interest.
ad70: 09 20 20 20 20 41 4e 44 20 20 20 20 42 2e 73 69 . AND B.si
ad80: 64 20 3d 20 50 2e 70 69 64 20 20 20 20 20 20 2d d = P.pid -
ad90: 2d 20 47 65 74 20 74 68 65 20 70 72 65 66 65 72 - Get the prefer
ada0: 65 64 20 62 72 61 6e 63 68 65 73 20 76 69 61 0a ed branches via.
adb0: 09 20 20 20 20 41 4e 44 20 20 20 20 42 58 2e 73 . AND BX.s
adc0: 69 64 20 3d 20 50 2e 73 69 64 20 20 20 20 20 2d id = P.sid -
add0: 2d 20 74 68 65 20 62 72 61 6e 63 68 20 73 79 6d - the branch sym
ade0: 62 6f 6c 73 0a 09 20 20 20 20 41 4e 44 20 20 20 bols.. AND
adf0: 20 42 58 2e 62 69 64 20 49 4e 20 24 74 68 65 73 BX.bid IN $thes
ae00: 65 74 20 20 2d 2d 20 4c 6f 6f 70 0a 09 7d 5d 5d et -- Loop..}]]
ae10: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 23 20 76 61 . }.. # va
ae20: 72 28 64 76 29 20 3d 20 64 69 63 74 20 28 69 74 r(dv) = dict (it
ae30: 65 6d 20 2d 3e 20 6c 69 73 74 20 28 69 74 65 6d em -> list (item
ae40: 29 29 2c 20 69 74 65 6d 20 20 3d 20 6c 69 73 74 )), item = list
ae50: 20 28 74 79 70 65 20 69 64 29 0a 20 20 20 20 74 (type id). t
ae60: 79 70 65 6d 65 74 68 6f 64 20 73 75 63 63 65 73 ypemethod succes
ae70: 73 6f 72 73 20 7b 64 76 20 62 72 61 6e 63 68 65 sors {dv branche
ae80: 73 7d 20 7b 0a 09 75 70 76 61 72 20 31 20 24 64 s} {..upvar 1 $d
ae90: 76 20 64 65 70 65 6e 64 65 6e 63 69 65 73 0a 09 v dependencies..
aea0: 23 20 54 68 65 20 66 69 72 73 74 20 72 65 76 69 # The first revi
aeb0: 73 69 6f 6e 20 63 6f 6d 6d 69 74 74 65 64 20 6f sion committed o
aec0: 6e 20 61 20 62 72 61 6e 63 68 2c 20 61 6e 64 20 n a branch, and
aed0: 61 6c 6c 20 62 72 61 6e 63 68 65 73 0a 09 23 20 all branches..#
aee0: 61 6e 64 20 74 61 67 73 20 77 68 69 63 68 20 68 and tags which h
aef0: 61 76 65 20 69 74 20 61 73 20 74 68 65 69 72 20 ave it as their
af00: 70 72 65 66 65 72 65 64 20 70 61 72 65 6e 74 20 prefered parent
af10: 61 72 65 20 74 68 65 0a 09 23 20 73 75 63 63 65 are the..# succe
af20: 73 73 6f 72 73 20 6f 66 20 61 20 62 72 61 6e 63 ssors of a branc
af30: 68 2e 0a 0a 09 73 65 74 20 74 68 65 73 65 74 20 h....set theset
af40: 28 27 5b 6a 6f 69 6e 20 24 62 72 61 6e 63 68 65 ('[join $branche
af50: 73 20 7b 27 2c 27 7d 5d 27 29 0a 09 66 6f 72 65 s {','}]')..fore
af60: 61 63 68 20 7b 62 69 64 20 63 68 69 6c 64 7d 20 ach {bid child}
af70: 5b 73 74 61 74 65 20 72 75 6e 20 5b 73 75 62 73 [state run [subs
af80: 74 20 2d 6e 6f 63 6f 6d 6d 61 6e 64 73 20 2d 6e t -nocommands -n
af90: 6f 62 61 63 6b 73 6c 61 73 68 65 73 20 7b 0a 09 obackslashes {..
afa0: 20 20 20 20 53 45 4c 45 43 54 20 42 2e 62 69 64 SELECT B.bid
afb0: 2c 20 52 2e 72 69 64 0a 09 20 20 20 20 46 52 4f , R.rid.. FRO
afc0: 4d 20 20 20 62 72 61 6e 63 68 20 42 2c 20 72 65 M branch B, re
afd0: 76 69 73 69 6f 6e 20 52 0a 09 20 20 20 20 57 48 vision R.. WH
afe0: 45 52 45 20 20 42 2e 62 69 64 20 49 4e 20 24 74 ERE B.bid IN $t
aff0: 68 65 73 65 74 20 20 20 20 20 2d 2d 20 52 65 73 heset -- Res
b000: 74 72 69 63 74 20 74 6f 20 62 72 61 6e 63 68 65 trict to branche
b010: 73 20 6f 66 20 69 6e 74 65 72 65 73 74 0a 09 20 s of interest..
b020: 20 20 20 41 4e 44 20 20 20 20 42 2e 66 69 72 73 AND B.firs
b030: 74 20 3d 20 52 2e 72 69 64 20 20 20 20 20 20 2d t = R.rid -
b040: 2d 20 47 65 74 20 66 69 72 73 74 20 72 65 76 69 - Get first revi
b050: 73 69 6f 6e 20 6f 6e 20 74 68 65 20 62 72 61 6e sion on the bran
b060: 63 68 0a 09 7d 5d 5d 20 7b 0a 09 20 20 20 20 6c ch..}]] {.. l
b070: 61 70 70 65 6e 64 20 64 65 70 65 6e 64 65 6e 63 append dependenc
b080: 69 65 73 28 5b 6c 69 73 74 20 73 79 6d 3a 3a 62 ies([list sym::b
b090: 72 61 6e 63 68 20 24 62 69 64 5d 29 20 5b 6c 69 ranch $bid]) [li
b0a0: 73 74 20 72 65 76 20 24 63 68 69 6c 64 5d 0a 09 st rev $child]..
b0b0: 7d 0a 09 66 6f 72 65 61 63 68 20 7b 62 69 64 20 }..foreach {bid
b0c0: 63 68 69 6c 64 7d 20 5b 73 74 61 74 65 20 72 75 child} [state ru
b0d0: 6e 20 5b 73 75 62 73 74 20 2d 6e 6f 63 6f 6d 6d n [subst -nocomm
b0e0: 61 6e 64 73 20 2d 6e 6f 62 61 63 6b 73 6c 61 73 ands -nobackslas
b0f0: 68 65 73 20 7b 0a 09 20 20 20 20 53 45 4c 45 43 hes {.. SELEC
b100: 54 20 42 2e 62 69 64 2c 20 42 58 2e 62 69 64 0a T B.bid, BX.bid.
b110: 09 20 20 20 20 46 52 4f 4d 20 20 20 62 72 61 6e . FROM bran
b120: 63 68 20 42 2c 20 70 72 65 66 65 72 65 64 70 61 ch B, preferedpa
b130: 72 65 6e 74 20 50 2c 20 62 72 61 6e 63 68 20 42 rent P, branch B
b140: 58 0a 09 20 20 20 20 57 48 45 52 45 20 20 42 2e X.. WHERE B.
b150: 62 69 64 20 49 4e 20 24 74 68 65 73 65 74 20 20 bid IN $theset
b160: 20 20 20 2d 2d 20 52 65 73 74 72 69 63 74 20 74 -- Restrict t
b170: 6f 20 62 72 61 6e 63 68 65 73 20 6f 66 20 69 6e o branches of in
b180: 74 65 72 65 73 74 0a 09 20 20 20 20 41 4e 44 20 terest.. AND
b190: 20 20 20 42 2e 73 69 64 20 3d 20 50 2e 70 69 64 B.sid = P.pid
b1a0: 20 20 20 20 20 20 20 20 2d 2d 20 47 65 74 20 73 -- Get s
b1b0: 75 62 6f 72 64 69 6e 61 74 65 20 62 72 61 6e 63 ubordinate branc
b1c0: 68 65 73 20 76 69 61 20 74 68 65 0a 09 20 20 20 hes via the..
b1d0: 20 41 4e 44 20 20 20 20 42 58 2e 73 69 64 20 3d AND BX.sid =
b1e0: 20 50 2e 73 69 64 20 20 20 20 20 20 20 2d 2d 20 P.sid --
b1f0: 70 72 65 66 65 72 65 64 20 70 61 72 65 6e 74 73 prefered parents
b200: 20 6f 66 20 74 68 65 69 72 20 73 79 6d 62 6f 6c of their symbol
b210: 73 0a 09 7d 5d 5d 20 7b 0a 09 20 20 20 20 6c 61 s..}]] {.. la
b220: 70 70 65 6e 64 20 64 65 70 65 6e 64 65 6e 63 69 ppend dependenci
b230: 65 73 28 5b 6c 69 73 74 20 73 79 6d 3a 3a 62 72 es([list sym::br
b240: 61 6e 63 68 20 24 62 69 64 5d 29 20 5b 6c 69 73 anch $bid]) [lis
b250: 74 20 73 79 6d 3a 3a 62 72 61 6e 63 68 20 24 63 t sym::branch $c
b260: 68 69 6c 64 5d 0a 09 7d 0a 09 66 6f 72 65 61 63 hild]..}..foreac
b270: 68 20 7b 62 69 64 20 63 68 69 6c 64 7d 20 5b 73 h {bid child} [s
b280: 74 61 74 65 20 72 75 6e 20 5b 73 75 62 73 74 20 tate run [subst
b290: 2d 6e 6f 63 6f 6d 6d 61 6e 64 73 20 2d 6e 6f 62 -nocommands -nob
b2a0: 61 63 6b 73 6c 61 73 68 65 73 20 7b 0a 09 20 20 ackslashes {..
b2b0: 20 20 53 45 4c 45 43 54 20 42 2e 62 69 64 2c 20 SELECT B.bid,
b2c0: 54 2e 74 69 64 0a 09 20 20 20 20 46 52 4f 4d 20 T.tid.. FROM
b2d0: 20 20 62 72 61 6e 63 68 20 42 2c 20 70 72 65 66 branch B, pref
b2e0: 65 72 65 64 70 61 72 65 6e 74 20 50 2c 20 74 61 eredparent P, ta
b2f0: 67 20 54 0a 09 20 20 20 20 57 48 45 52 45 20 20 g T.. WHERE
b300: 42 2e 62 69 64 20 49 4e 20 24 74 68 65 73 65 74 B.bid IN $theset
b310: 20 20 20 20 20 2d 2d 20 52 65 73 74 72 69 63 74 -- Restrict
b320: 20 74 6f 20 62 72 61 6e 63 68 65 73 20 6f 66 20 to branches of
b330: 69 6e 74 65 72 65 73 74 0a 09 20 20 20 20 41 4e interest.. AN
b340: 44 20 20 20 20 42 2e 73 69 64 20 3d 20 50 2e 70 D B.sid = P.p
b350: 69 64 20 20 20 20 20 20 20 20 2d 2d 20 47 65 74 id -- Get
b360: 20 73 75 62 6f 72 64 69 6e 61 74 65 20 74 61 67 subordinate tag
b370: 73 20 76 69 61 20 74 68 65 0a 09 20 20 20 20 41 s via the.. A
b380: 4e 44 20 20 20 20 54 2e 73 69 64 20 3d 20 50 2e ND T.sid = P.
b390: 73 69 64 20 20 20 20 20 20 20 20 2d 2d 20 70 72 sid -- pr
b3a0: 65 66 65 72 65 64 20 70 61 72 65 6e 74 73 20 6f efered parents o
b3b0: 66 20 74 68 65 69 72 20 73 79 6d 62 6f 6c 73 0a f their symbols.
b3c0: 09 7d 5d 5d 20 7b 0a 09 20 20 20 20 6c 61 70 70 .}]] {.. lapp
b3d0: 65 6e 64 20 64 65 70 65 6e 64 65 6e 63 69 65 73 end dependencies
b3e0: 28 5b 6c 69 73 74 20 73 79 6d 3a 3a 62 72 61 6e ([list sym::bran
b3f0: 63 68 20 24 62 69 64 5d 29 20 5b 6c 69 73 74 20 ch $bid]) [list
b400: 73 79 6d 3a 3a 74 61 67 20 24 63 68 69 6c 64 5d sym::tag $child]
b410: 0a 09 7d 0a 09 72 65 74 75 72 6e 0a 20 20 20 20 ..}..return.
b420: 7d 0a 0a 20 20 20 20 23 20 72 65 73 75 6c 74 20 }.. # result
b430: 3d 20 6c 69 73 74 20 28 63 68 61 6e 67 65 73 65 = list (changese
b440: 74 2d 69 64 29 0a 20 20 20 20 74 79 70 65 6d 65 t-id). typeme
b450: 74 68 6f 64 20 63 73 5f 73 75 63 63 65 73 73 6f thod cs_successo
b460: 72 73 20 7b 62 72 61 6e 63 68 65 73 7d 20 7b 0a rs {branches} {.
b470: 20 20 20 20 20 20 20 20 23 20 54 68 69 73 20 69 # This i
b480: 73 20 61 20 76 61 72 69 61 6e 74 20 6f 66 20 27 s a variant of '
b490: 73 75 63 63 65 73 73 6f 72 73 27 20 77 68 69 63 successors' whic
b4a0: 68 20 6d 61 70 73 20 74 68 65 20 6c 6f 77 2d 6c h maps the low-l
b4b0: 65 76 65 6c 0a 20 20 20 20 20 20 20 20 23 20 64 evel. # d
b4c0: 61 74 61 20 64 69 72 65 63 74 6c 79 20 74 6f 20 ata directly to
b4d0: 74 68 65 20 61 73 73 6f 63 69 61 74 65 64 20 63 the associated c
b4e0: 68 61 6e 67 65 73 65 74 73 2e 20 49 2e 65 2e 20 hangesets. I.e.
b4f0: 69 6e 73 74 65 61 64 0a 20 20 20 20 20 20 20 20 instead.
b500: 23 20 6d 69 6c 6c 69 6f 6e 73 20 6f 66 20 64 65 # millions of de
b510: 70 65 6e 64 65 6e 63 79 20 70 61 69 72 73 20 28 pendency pairs (
b520: 69 6e 20 65 78 74 72 65 6d 65 20 63 61 73 65 73 in extreme cases
b530: 20 28 45 78 61 6d 70 6c 65 3a 20 54 63 6c 0a 20 (Example: Tcl.
b540: 20 20 20 20 20 20 20 23 20 43 56 53 29 29 20 77 # CVS)) w
b550: 65 20 72 65 74 75 72 6e 20 61 20 76 65 72 79 20 e return a very
b560: 73 68 6f 72 74 20 61 6e 64 20 6d 75 63 68 20 6d short and much m
b570: 6f 72 65 20 6d 61 6e 61 67 65 61 62 6c 65 20 6c ore manageable l
b580: 69 73 74 0a 20 20 20 20 20 20 20 20 23 20 6f 66 ist. # of
b590: 20 63 68 61 6e 67 65 73 65 74 73 2e 0a 0a 09 73 changesets....s
b5a0: 65 74 20 74 68 65 73 65 74 20 28 27 5b 6a 6f 69 et theset ('[joi
b5b0: 6e 20 24 62 72 61 6e 63 68 65 73 20 7b 27 2c 27 n $branches {','
b5c0: 7d 5d 27 29 0a 20 20 20 20 20 20 20 20 72 65 74 }]'). ret
b5d0: 75 72 6e 20 5b 73 74 61 74 65 20 72 75 6e 20 5b urn [state run [
b5e0: 73 75 62 73 74 20 2d 6e 6f 63 6f 6d 6d 61 6e 64 subst -nocommand
b5f0: 73 20 2d 6e 6f 62 61 63 6b 73 6c 61 73 68 65 73 s -nobackslashes
b600: 20 7b 0a 09 20 20 20 20 53 45 4c 45 43 54 20 43 {.. SELECT C
b610: 2e 63 69 64 0a 09 20 20 20 20 46 52 4f 4d 20 20 .cid.. FROM
b620: 20 62 72 61 6e 63 68 20 42 2c 20 72 65 76 69 73 branch B, revis
b630: 69 6f 6e 20 52 2c 20 63 73 69 74 65 6d 20 43 49 ion R, csitem CI
b640: 2c 20 63 68 61 6e 67 65 73 65 74 20 43 0a 09 20 , changeset C..
b650: 20 20 20 57 48 45 52 45 20 20 42 2e 62 69 64 20 WHERE B.bid
b660: 49 4e 20 24 74 68 65 73 65 74 20 20 20 20 20 2d IN $theset -
b670: 2d 20 52 65 73 74 72 69 63 74 20 74 6f 20 62 72 - Restrict to br
b680: 61 6e 63 68 65 73 20 6f 66 20 69 6e 74 65 72 65 anches of intere
b690: 73 74 0a 09 20 20 20 20 41 4e 44 20 20 20 20 42 st.. AND B
b6a0: 2e 66 69 72 73 74 20 3d 20 52 2e 72 69 64 09 2d .first = R.rid.-
b6b0: 2d 20 47 65 74 20 66 69 72 73 74 20 72 65 76 69 - Get first revi
b6c0: 73 69 6f 6e 20 6f 6e 20 74 68 65 20 62 72 61 6e sion on the bran
b6d0: 63 68 0a 20 20 20 20 20 20 20 20 20 20 20 20 41 ch. A
b6e0: 4e 44 20 20 20 20 43 49 2e 69 69 64 20 3d 20 52 ND CI.iid = R
b6f0: 2e 72 69 64 20 20 20 20 20 20 20 2d 2d 20 53 65 .rid -- Se
b700: 6c 65 63 74 20 61 6c 6c 20 63 68 61 6e 67 65 73 lect all changes
b710: 65 74 73 0a 20 20 20 20 20 20 20 20 20 20 20 20 ets.
b720: 41 4e 44 20 20 20 20 43 2e 63 69 64 20 3d 20 43 AND C.cid = C
b730: 49 2e 63 69 64 09 2d 2d 20 63 6f 6e 74 61 69 6e I.cid.-- contain
b740: 69 6e 67 20 74 68 69 73 20 72 65 76 69 73 69 6f ing this revisio
b750: 6e 0a 20 20 20 20 20 20 20 20 20 20 20 20 41 4e n. AN
b760: 44 20 20 20 20 43 2e 74 79 70 65 20 3d 20 30 09 D C.type = 0.
b770: 09 2d 2d 20 77 68 69 63 68 20 61 72 65 20 72 65 .-- which are re
b780: 76 69 73 69 6f 6e 20 63 68 61 6e 67 65 73 65 74 vision changeset
b790: 73 0a 20 20 20 20 55 4e 49 4f 4e 0a 09 20 20 20 s. UNION..
b7a0: 20 53 45 4c 45 43 54 20 43 2e 63 69 64 0a 09 20 SELECT C.cid..
b7b0: 20 20 20 46 52 4f 4d 20 20 20 62 72 61 6e 63 68 FROM branch
b7c0: 20 42 2c 20 70 72 65 66 65 72 65 64 70 61 72 65 B, preferedpare
b7d0: 6e 74 20 50 2c 20 62 72 61 6e 63 68 20 42 58 2c nt P, branch BX,
b7e0: 20 63 73 69 74 65 6d 20 43 49 2c 20 63 68 61 6e csitem CI, chan
b7f0: 67 65 73 65 74 20 43 0a 09 20 20 20 20 57 48 45 geset C.. WHE
b800: 52 45 20 20 42 2e 62 69 64 20 49 4e 20 24 74 68 RE B.bid IN $th
b810: 65 73 65 74 20 20 20 20 20 2d 2d 20 52 65 73 74 eset -- Rest
b820: 72 69 63 74 20 74 6f 20 62 72 61 6e 63 68 65 73 rict to branches
b830: 20 6f 66 20 69 6e 74 65 72 65 73 74 0a 09 20 20 of interest..
b840: 20 20 41 4e 44 20 20 20 20 42 2e 73 69 64 20 3d AND B.sid =
b850: 20 50 2e 70 69 64 09 2d 2d 20 47 65 74 20 73 75 P.pid.-- Get su
b860: 62 6f 72 64 69 6e 61 74 65 20 62 72 61 6e 63 68 bordinate branch
b870: 65 73 20 76 69 61 20 74 68 65 0a 09 20 20 20 20 es via the..
b880: 41 4e 44 20 20 20 20 42 58 2e 73 69 64 20 3d 20 AND BX.sid =
b890: 50 2e 73 69 64 09 2d 2d 20 70 72 65 66 65 72 65 P.sid.-- prefere
b8a0: 64 20 70 61 72 65 6e 74 73 20 6f 66 20 74 68 65 d parents of the
b8b0: 69 72 20 73 79 6d 62 6f 6c 73 0a 20 20 20 20 20 ir symbols.
b8c0: 20 20 20 20 20 20 20 41 4e 44 20 20 20 20 43 49 AND CI
b8d0: 2e 69 69 64 20 3d 20 42 58 2e 62 69 64 20 20 20 .iid = BX.bid
b8e0: 20 20 20 2d 2d 20 53 65 6c 65 63 74 20 61 6c 6c -- Select all
b8f0: 20 63 68 61 6e 67 65 73 65 74 73 0a 20 20 20 20 changesets.
b900: 20 20 20 20 20 20 20 20 41 4e 44 20 20 20 20 43 AND C
b910: 2e 63 69 64 20 3d 20 43 49 2e 63 69 64 09 2d 2d .cid = CI.cid.--
b920: 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74 68 65 20 containing the
b930: 73 75 62 6f 72 64 69 6e 61 74 65 20 62 72 61 6e subordinate bran
b940: 63 68 65 73 0a 20 20 20 20 20 20 20 20 20 20 20 ches.
b950: 20 41 4e 44 20 20 20 20 43 2e 74 79 70 65 20 3d AND C.type =
b960: 20 32 09 09 2d 2d 20 77 68 69 63 68 20 61 72 65 2..-- which are
b970: 20 62 72 61 6e 63 68 20 63 68 61 6e 67 65 73 65 branch changese
b980: 74 73 0a 20 20 20 20 55 4e 49 4f 4e 0a 09 20 20 ts. UNION..
b990: 20 20 53 45 4c 45 43 54 20 43 2e 63 69 64 0a 09 SELECT C.cid..
b9a0: 20 20 20 20 46 52 4f 4d 20 20 20 62 72 61 6e 63 FROM branc
b9b0: 68 20 42 2c 20 70 72 65 66 65 72 65 64 70 61 72 h B, preferedpar
b9c0: 65 6e 74 20 50 2c 20 74 61 67 20 54 2c 20 63 73 ent P, tag T, cs
b9d0: 69 74 65 6d 20 43 49 2c 20 63 68 61 6e 67 65 73 item CI, changes
b9e0: 65 74 20 43 0a 09 20 20 20 20 57 48 45 52 45 20 et C.. WHERE
b9f0: 20 42 2e 62 69 64 20 49 4e 20 24 74 68 65 73 65 B.bid IN $these
ba00: 74 20 20 20 20 20 2d 2d 20 52 65 73 74 72 69 63 t -- Restric
ba10: 74 20 74 6f 20 62 72 61 6e 63 68 65 73 20 6f 66 t to branches of
ba20: 20 69 6e 74 65 72 65 73 74 0a 09 20 20 20 20 41 interest.. A
ba30: 4e 44 20 20 20 20 42 2e 73 69 64 20 3d 20 50 2e ND B.sid = P.
ba40: 70 69 64 09 2d 2d 20 47 65 74 20 73 75 62 6f 72 pid.-- Get subor
ba50: 64 69 6e 61 74 65 20 74 61 67 73 20 76 69 61 20 dinate tags via
ba60: 74 68 65 0a 09 20 20 20 20 41 4e 44 20 20 20 20 the.. AND
ba70: 54 2e 73 69 64 20 3d 20 50 2e 73 69 64 09 2d 2d T.sid = P.sid.--
ba80: 20 70 72 65 66 65 72 65 64 20 70 61 72 65 6e 74 prefered parent
ba90: 73 20 6f 66 20 74 68 65 69 72 20 73 79 6d 62 6f s of their symbo
baa0: 6c 73 0a 20 20 20 20 20 20 20 20 20 20 20 20 41 ls. A
bab0: 4e 44 20 20 20 20 43 49 2e 69 69 64 20 3d 20 54 ND CI.iid = T
bac0: 2e 74 69 64 20 20 20 20 20 20 20 2d 2d 20 53 65 .tid -- Se
bad0: 6c 65 63 74 20 61 6c 6c 20 63 68 61 6e 67 65 73 lect all changes
bae0: 65 74 73 0a 20 20 20 20 20 20 20 20 20 20 20 20 ets.
baf0: 41 4e 44 20 20 20 20 43 2e 63 69 64 20 3d 20 43 AND C.cid = C
bb00: 49 2e 63 69 64 09 2d 2d 20 63 6f 6e 74 61 69 6e I.cid.-- contain
bb10: 69 6e 67 20 74 68 65 20 73 75 62 6f 72 64 69 6e ing the subordin
bb20: 61 74 65 20 74 61 67 73 0a 20 20 20 20 20 20 20 ate tags.
bb30: 20 20 20 20 20 41 4e 44 20 20 20 20 43 2e 74 79 AND C.ty
bb40: 70 65 20 3d 20 31 09 09 2d 2d 20 77 68 69 63 68 pe = 1..-- which
bb50: 20 61 72 65 20 74 61 67 20 63 68 61 6e 67 65 73 are tag changes
bb60: 65 74 73 0a 09 7d 5d 5d 0a 09 72 65 74 75 72 6e ets..}]]..return
bb70: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 74 79 70 65 . }.. type
bb80: 6d 65 74 68 6f 64 20 6c 69 6d 69 74 73 20 7b 62 method limits {b
bb90: 72 61 6e 63 68 65 73 7d 20 7b 0a 09 23 20 4e 6f ranches} {..# No
bba0: 74 65 73 2e 20 54 68 69 73 20 6d 65 74 68 6f 64 tes. This method
bbb0: 20 65 78 69 73 74 73 20 6f 6e 6c 79 20 66 6f 72 exists only for
bbc0: 20 62 72 61 6e 63 68 65 73 2e 20 49 74 20 69 73 branches. It is
bbd0: 20 6e 65 65 64 65 64 20 74 6f 0a 09 23 20 67 65 needed to..# ge
bbe0: 74 20 64 65 74 61 69 6c 65 64 20 69 6e 66 6f 72 t detailed infor
bbf0: 6d 61 74 69 6f 6e 20 61 62 6f 75 74 20 61 20 62 mation about a b
bc00: 61 63 6b 77 61 72 64 20 62 72 61 6e 63 68 2e 20 ackward branch.
bc10: 49 74 20 64 6f 65 73 0a 09 23 20 6e 6f 74 20 61 It does..# not a
bc20: 70 70 6c 79 20 74 6f 20 74 61 67 73 2c 20 6e 6f pply to tags, no
bc30: 72 20 72 65 76 69 73 69 6f 6e 73 2e 20 54 68 65 r revisions. The
bc40: 20 71 75 65 72 69 65 73 20 63 61 6e 20 61 6c 73 queries can als
bc50: 6f 0a 09 23 20 72 65 73 74 72 69 63 74 20 74 68 o..# restrict th
bc60: 65 6d 73 65 6c 76 65 73 20 74 6f 20 74 68 65 20 emselves to the
bc70: 72 65 76 69 73 69 6f 6e 20 73 75 63 65 73 73 6f revision sucesso
bc80: 72 73 2f 70 72 65 64 65 63 65 73 73 6f 72 73 0a rs/predecessors.
bc90: 09 23 20 6f 66 20 62 72 61 6e 63 68 65 73 2c 20 .# of branches,
bca0: 61 73 20 6f 6e 6c 79 20 74 68 65 79 20 68 61 76 as only they hav
bcb0: 65 20 6f 72 64 65 72 69 6e 67 20 64 61 74 61 20 e ordering data
bcc0: 61 6e 64 20 74 68 75 73 20 63 61 6e 0a 09 23 20 and thus can..#
bcd0: 63 61 75 73 65 20 74 68 65 20 62 61 63 6b 77 61 cause the backwa
bce0: 72 64 6e 65 73 73 2e 0a 0a 09 73 65 74 20 74 68 rdness....set th
bcf0: 65 73 65 74 20 28 27 5b 6a 6f 69 6e 20 24 62 72 eset ('[join $br
bd00: 61 6e 63 68 65 73 20 7b 27 2c 27 7d 5d 27 29 0a anches {','}]').
bd10: 0a 09 73 65 74 20 6d 61 78 70 20 5b 73 74 61 74 ..set maxp [stat
bd20: 65 20 72 75 6e 20 5b 73 75 62 73 74 20 2d 6e 6f e run [subst -no
bd30: 63 6f 6d 6d 61 6e 64 73 20 2d 6e 6f 62 61 63 6b commands -noback
bd40: 73 6c 61 73 68 65 73 20 7b 0a 09 20 20 20 20 2d slashes {.. -
bd50: 2d 20 6d 61 78 69 6d 61 6c 20 70 72 65 64 65 63 - maximal predec
bd60: 65 73 73 6f 72 20 70 6f 73 69 74 69 6f 6e 20 70 essor position p
bd70: 65 72 20 62 72 61 6e 63 68 0a 09 20 20 20 20 53 er branch.. S
bd80: 45 4c 45 43 54 20 42 2e 62 69 64 2c 20 4d 41 58 ELECT B.bid, MAX
bd90: 20 28 43 4f 2e 70 6f 73 29 0a 09 20 20 20 20 46 (CO.pos).. F
bda0: 52 4f 4d 20 20 20 62 72 61 6e 63 68 20 42 2c 20 ROM branch B,
bdb0: 72 65 76 69 73 69 6f 6e 20 52 2c 20 63 73 69 74 revision R, csit
bdc0: 65 6d 20 43 49 2c 20 63 68 61 6e 67 65 73 65 74 em CI, changeset
bdd0: 20 43 2c 20 63 73 6f 72 64 65 72 20 43 4f 0a 09 C, csorder CO..
bde0: 20 20 20 20 57 48 45 52 45 20 20 42 2e 62 69 64 WHERE B.bid
bdf0: 20 49 4e 20 24 74 68 65 73 65 74 20 20 20 20 20 IN $theset
be00: 2d 2d 20 52 65 73 74 72 69 63 74 20 74 6f 20 62 -- Restrict to b
be10: 72 61 6e 63 68 65 73 20 6f 66 20 69 6e 74 65 72 ranches of inter
be20: 65 73 74 0a 09 20 20 20 20 41 4e 44 20 20 20 20 est.. AND
be30: 42 2e 72 6f 6f 74 20 3d 20 52 2e 72 69 64 20 20 B.root = R.rid
be40: 20 20 20 20 20 2d 2d 20 47 65 74 20 62 72 61 6e -- Get bran
be50: 63 68 20 72 6f 6f 74 20 72 65 76 69 73 69 6f 6e ch root revision
be60: 73 0a 09 20 20 20 20 41 4e 44 20 20 20 20 43 49 s.. AND CI
be70: 2e 69 69 64 20 3d 20 52 2e 72 69 64 20 20 20 20 .iid = R.rid
be80: 20 20 20 2d 2d 20 47 65 74 20 63 68 61 6e 67 65 -- Get change
be90: 73 65 74 73 20 63 6f 6e 74 61 69 6e 69 6e 67 20 sets containing
bea0: 74 68 65 0a 09 20 20 20 20 41 4e 44 20 20 20 20 the.. AND
beb0: 43 2e 63 69 64 20 3d 20 43 49 2e 63 69 64 20 20 C.cid = CI.cid
bec0: 20 20 20 20 20 2d 2d 20 72 6f 6f 74 20 72 65 76 -- root rev
bed0: 69 73 69 6f 6e 73 2c 20 77 68 69 63 68 20 61 72 isions, which ar
bee0: 65 0a 09 20 20 20 20 41 4e 44 20 20 20 20 43 2e e.. AND C.
bef0: 74 79 70 65 20 3d 20 30 20 20 20 20 20 20 20 20 type = 0
bf00: 20 20 20 2d 2d 20 72 65 76 69 73 69 6f 6e 20 63 -- revision c
bf10: 68 61 6e 67 65 73 65 74 73 0a 09 20 20 20 20 41 hangesets.. A
bf20: 4e 44 20 20 20 20 43 4f 2e 63 69 64 20 3d 20 43 ND CO.cid = C
bf30: 2e 63 69 64 20 20 20 20 20 20 20 2d 2d 20 47 65 .cid -- Ge
bf40: 74 20 74 68 65 69 72 20 74 6f 70 6f 6c 6f 67 69 t their topologi
bf50: 63 61 6c 20 6f 72 64 65 72 69 6e 67 0a 09 20 20 cal ordering..
bf60: 20 20 47 52 4f 55 50 20 42 59 20 42 2e 62 69 64 GROUP BY B.bid
bf70: 0a 09 7d 5d 5d 0a 0a 09 73 65 74 20 6d 69 6e 73 ..}]]...set mins
bf80: 20 5b 73 74 61 74 65 20 72 75 6e 20 5b 73 75 62 [state run [sub
bf90: 73 74 20 2d 6e 6f 63 6f 6d 6d 61 6e 64 73 20 2d st -nocommands -
bfa0: 6e 6f 62 61 63 6b 73 6c 61 73 68 65 73 20 7b 0a nobackslashes {.
bfb0: 09 20 20 20 20 2d 2d 20 6d 69 6e 69 6d 61 6c 20 . -- minimal
bfc0: 73 75 63 63 65 73 73 6f 72 20 70 6f 73 69 74 69 successor positi
bfd0: 6f 6e 20 70 65 72 20 62 72 61 6e 63 68 0a 09 20 on per branch..
bfe0: 20 20 20 53 45 4c 45 43 54 20 42 2e 62 69 64 2c SELECT B.bid,
bff0: 20 4d 49 4e 20 28 43 4f 2e 70 6f 73 29 0a 09 20 MIN (CO.pos)..
c000: 20 20 20 46 52 4f 4d 20 20 20 62 72 61 6e 63 68 FROM branch
c010: 20 42 2c 20 72 65 76 69 73 69 6f 6e 20 52 2c 20 B, revision R,
c020: 63 73 69 74 65 6d 20 43 49 2c 20 63 68 61 6e 67 csitem CI, chang
c030: 65 73 65 74 20 43 2c 20 63 73 6f 72 64 65 72 20 eset C, csorder
c040: 43 4f 0a 09 20 20 20 20 57 48 45 52 45 20 20 42 CO.. WHERE B
c050: 2e 62 69 64 20 49 4e 20 24 74 68 65 73 65 74 20 .bid IN $theset
c060: 20 20 20 20 2d 2d 20 52 65 73 74 72 69 63 74 20 -- Restrict
c070: 74 6f 20 62 72 61 6e 63 68 65 73 20 6f 66 20 69 to branches of i
c080: 6e 74 65 72 65 73 74 0a 09 20 20 20 20 41 4e 44 nterest.. AND
c090: 20 20 20 20 42 2e 66 69 72 73 74 20 3d 20 52 2e B.first = R.
c0a0: 72 69 64 20 20 20 20 20 20 2d 2d 20 47 65 74 20 rid -- Get
c0b0: 74 68 65 20 66 69 72 73 74 20 72 65 76 69 73 69 the first revisi
c0c0: 6f 6e 73 20 6f 6e 20 74 68 65 20 62 72 61 6e 63 ons on the branc
c0d0: 68 65 73 0a 09 20 20 20 20 41 4e 44 20 20 20 20 hes.. AND
c0e0: 43 49 2e 69 69 64 20 3d 20 52 2e 72 69 64 20 20 CI.iid = R.rid
c0f0: 20 20 20 20 20 2d 2d 20 47 65 74 20 63 68 61 6e -- Get chan
c100: 67 65 73 65 74 73 20 63 6f 6e 74 61 69 6e 69 6e gesets containin
c110: 67 20 74 68 65 0a 09 20 20 20 20 41 4e 44 20 20 g the.. AND
c120: 20 20 43 2e 63 69 64 20 3d 20 43 49 2e 63 69 64 C.cid = CI.cid
c130: 09 2d 2d 20 66 69 72 73 74 20 72 65 76 69 73 69 .-- first revisi
c140: 6f 6e 73 2c 20 77 68 69 63 68 20 61 72 65 0a 09 ons, which are..
c150: 20 20 20 20 41 4e 44 20 20 20 20 43 2e 74 79 70 AND C.typ
c160: 65 20 3d 20 30 09 09 2d 2d 20 72 65 76 69 73 69 e = 0..-- revisi
c170: 6f 6e 20 63 68 61 6e 67 65 73 65 74 73 0a 09 20 on changesets..
c180: 20 20 20 41 4e 44 20 20 20 20 43 4f 2e 63 69 64 AND CO.cid
c190: 20 3d 20 43 2e 63 69 64 09 2d 2d 20 47 65 74 20 = C.cid.-- Get
c1a0: 74 68 65 69 72 20 74 6f 70 6f 6c 6f 67 69 63 61 their topologica
c1b0: 6c 20 6f 72 64 65 72 69 6e 67 0a 09 20 20 20 20 l ordering..
c1c0: 47 52 4f 55 50 20 42 59 20 42 2e 62 69 64 0a 09 GROUP BY B.bid..
c1d0: 7d 5d 5d 0a 0a 20 20 20 20 20 20 20 20 72 65 74 }]].. ret
c1e0: 75 72 6e 20 5b 6c 69 73 74 20 24 6d 61 78 70 20 urn [list $maxp
c1f0: 24 6d 69 6e 73 5d 0a 20 20 20 20 7d 0a 0a 20 20 $mins]. }..
c200: 20 20 23 20 23 20 23 23 20 23 23 23 20 23 23 23 # # ## ### ###
c210: 23 23 20 23 23 23 23 23 23 23 23 20 23 23 23 23 ## ######## ####
c220: 23 23 23 23 23 23 23 23 23 0a 20 20 20 20 23 23 #########. ##
c230: 20 43 6f 6e 66 69 67 75 72 61 74 69 6f 6e 0a 0a Configuration..
c240: 20 20 20 20 70 72 61 67 6d 61 20 2d 68 61 73 69 pragma -hasi
c250: 6e 73 74 61 6e 63 65 73 20 20 20 6e 6f 20 3b 20 nstances no ;
c260: 23 20 73 69 6e 67 6c 65 74 6f 6e 0a 20 20 20 20 # singleton.
c270: 70 72 61 67 6d 61 20 2d 68 61 73 74 79 70 65 69 pragma -hastypei
c280: 6e 66 6f 20 20 20 20 6e 6f 20 3b 20 23 20 6e 6f nfo no ; # no
c290: 20 69 6e 74 72 6f 73 70 65 63 74 69 6f 6e 0a 20 introspection.
c2a0: 20 20 20 70 72 61 67 6d 61 20 2d 68 61 73 74 79 pragma -hasty
c2b0: 70 65 64 65 73 74 72 6f 79 20 6e 6f 20 3b 20 23 pedestroy no ; #
c2c0: 20 69 6d 6d 6f 72 74 61 6c 0a 7d 0a 0a 23 20 23 immortal.}..# #
c2d0: 20 23 23 20 23 23 23 20 23 23 23 23 23 20 23 23 ## ### ##### ##
c2e0: 23 23 23 23 23 23 20 23 23 23 23 23 23 23 23 23 ###### #########
c2f0: 23 23 23 23 20 23 23 23 23 23 23 23 23 23 23 23 #### ###########
c300: 23 23 23 23 23 23 23 23 23 23 0a 23 23 0a 0a 6e ##########.##..n
c310: 61 6d 65 73 70 61 63 65 20 65 76 61 6c 20 3a 3a amespace eval ::
c320: 76 63 3a 3a 66 6f 73 73 69 6c 3a 3a 69 6d 70 6f vc::fossil::impo
c330: 72 74 3a 3a 63 76 73 3a 3a 70 72 6f 6a 65 63 74 rt::cvs::project
c340: 20 7b 0a 20 20 20 20 6e 61 6d 65 73 70 61 63 65 {. namespace
c350: 20 65 78 70 6f 72 74 20 72 65 76 0a 20 20 20 20 export rev.
c360: 6e 61 6d 65 73 70 61 63 65 20 65 76 61 6c 20 72 namespace eval r
c370: 65 76 20 7b 0a 09 6e 61 6d 65 73 70 61 63 65 20 ev {..namespace
c380: 69 6d 70 6f 72 74 20 3a 3a 76 63 3a 3a 66 6f 73 import ::vc::fos
c390: 73 69 6c 3a 3a 69 6d 70 6f 72 74 3a 3a 63 76 73 sil::import::cvs
c3a0: 3a 3a 73 74 61 74 65 0a 09 6e 61 6d 65 73 70 61 ::state..namespa
c3b0: 63 65 20 69 6d 70 6f 72 74 20 3a 3a 76 63 3a 3a ce import ::vc::
c3c0: 66 6f 73 73 69 6c 3a 3a 69 6d 70 6f 72 74 3a 3a fossil::import::
c3d0: 63 76 73 3a 3a 69 6e 74 65 67 72 69 74 79 0a 09 cvs::integrity..
c3e0: 6e 61 6d 65 73 70 61 63 65 20 69 6d 70 6f 72 74 namespace import
c3f0: 20 3a 3a 76 63 3a 3a 74 6f 6f 6c 73 3a 3a 6d 69 ::vc::tools::mi
c400: 73 63 3a 3a 2a 0a 09 6e 61 6d 65 73 70 61 63 65 sc::*..namespace
c410: 20 69 6d 70 6f 72 74 20 3a 3a 76 63 3a 3a 74 6f import ::vc::to
c420: 6f 6c 73 3a 3a 74 72 6f 75 62 6c 65 0a 09 6e 61 ols::trouble..na
c430: 6d 65 73 70 61 63 65 20 69 6d 70 6f 72 74 20 3a mespace import :
c440: 3a 76 63 3a 3a 74 6f 6f 6c 73 3a 3a 6c 6f 67 0a :vc::tools::log.
c450: 09 6c 6f 67 20 72 65 67 69 73 74 65 72 20 63 73 .log register cs
c460: 65 74 73 0a 0a 09 23 20 53 65 74 20 75 70 20 74 ets...# Set up t
c470: 68 65 20 68 65 6c 70 65 72 20 73 69 6e 67 6c 65 he helper single
c480: 74 6f 6e 73 0a 09 6e 61 6d 65 73 70 61 63 65 20 tons..namespace
c490: 65 76 61 6c 20 72 65 76 20 7b 0a 09 20 20 20 20 eval rev {..
c4a0: 6e 61 6d 65 73 70 61 63 65 20 69 6d 70 6f 72 74 namespace import
c4b0: 20 3a 3a 76 63 3a 3a 66 6f 73 73 69 6c 3a 3a 69 ::vc::fossil::i
c4c0: 6d 70 6f 72 74 3a 3a 63 76 73 3a 3a 73 74 61 74 mport::cvs::stat
c4d0: 65 0a 09 20 20 20 20 6e 61 6d 65 73 70 61 63 65 e.. namespace
c4e0: 20 69 6d 70 6f 72 74 20 3a 3a 76 63 3a 3a 66 6f import ::vc::fo
c4f0: 73 73 69 6c 3a 3a 69 6d 70 6f 72 74 3a 3a 63 76 ssil::import::cv
c500: 73 3a 3a 69 6e 74 65 67 72 69 74 79 0a 09 7d 0a s::integrity..}.
c510: 09 6e 61 6d 65 73 70 61 63 65 20 65 76 61 6c 20 .namespace eval
c520: 73 79 6d 3a 3a 74 61 67 20 7b 0a 09 20 20 20 20 sym::tag {..
c530: 6e 61 6d 65 73 70 61 63 65 20 69 6d 70 6f 72 74 namespace import
c540: 20 3a 3a 76 63 3a 3a 66 6f 73 73 69 6c 3a 3a 69 ::vc::fossil::i
c550: 6d 70 6f 72 74 3a 3a 63 76 73 3a 3a 73 74 61 74 mport::cvs::stat
c560: 65 0a 09 20 20 20 20 6e 61 6d 65 73 70 61 63 65 e.. namespace
c570: 20 69 6d 70 6f 72 74 20 3a 3a 76 63 3a 3a 66 6f import ::vc::fo
c580: 73 73 69 6c 3a 3a 69 6d 70 6f 72 74 3a 3a 63 76 ssil::import::cv
c590: 73 3a 3a 69 6e 74 65 67 72 69 74 79 0a 09 7d 0a s::integrity..}.
c5a0: 09 6e 61 6d 65 73 70 61 63 65 20 65 76 61 6c 20 .namespace eval
c5b0: 73 79 6d 3a 3a 62 72 61 6e 63 68 20 7b 0a 09 20 sym::branch {..
c5c0: 20 20 20 6e 61 6d 65 73 70 61 63 65 20 69 6d 70 namespace imp
c5d0: 6f 72 74 20 3a 3a 76 63 3a 3a 66 6f 73 73 69 6c ort ::vc::fossil
c5e0: 3a 3a 69 6d 70 6f 72 74 3a 3a 63 76 73 3a 3a 73 ::import::cvs::s
c5f0: 74 61 74 65 0a 09 20 20 20 20 6e 61 6d 65 73 70 tate.. namesp
c600: 61 63 65 20 69 6d 70 6f 72 74 20 3a 3a 76 63 3a ace import ::vc:
c610: 3a 66 6f 73 73 69 6c 3a 3a 69 6d 70 6f 72 74 3a :fossil::import:
c620: 3a 63 76 73 3a 3a 69 6e 74 65 67 72 69 74 79 0a :cvs::integrity.
c630: 09 7d 0a 20 20 20 20 7d 0a 7d 0a 0a 23 20 23 20 .}. }.}..# #
c640: 23 23 20 23 23 23 20 23 23 23 23 23 20 23 23 23 ## ### ##### ###
c650: 23 23 23 23 23 20 23 23 23 23 23 23 23 23 23 23 ##### ##########
c660: 23 23 23 20 23 23 23 23 23 23 23 23 23 23 23 23 ### ############
c670: 23 23 23 23 23 23 23 23 23 0a 23 23 20 52 65 61 #########.## Rea
c680: 64 79 0a 0a 70 61 63 6b 61 67 65 20 70 72 6f 76 dy..package prov
c690: 69 64 65 20 76 63 3a 3a 66 6f 73 73 69 6c 3a 3a ide vc::fossil::
c6a0: 69 6d 70 6f 72 74 3a 3a 63 76 73 3a 3a 70 72 6f import::cvs::pro
c6b0: 6a 65 63 74 3a 3a 72 65 76 20 31 2e 30 0a 72 65 ject::rev 1.0.re
c6c0: 74 75 72 6e 0a turn.