Merge rsync://rsync.kernel.org/pub/scm/gitk/gitk
This commit is contained in:
commit
85c1f337be
588
gitk
588
gitk
@ -7,13 +7,21 @@ exec wish "$0" -- "${1+$@}"
|
|||||||
# and distributed under the terms of the GNU General Public Licence,
|
# and distributed under the terms of the GNU General Public Licence,
|
||||||
# either version 2, or (at your option) any later version.
|
# either version 2, or (at your option) any later version.
|
||||||
|
|
||||||
# CVS $Revision: 1.24 $
|
|
||||||
|
|
||||||
proc getcommits {rargs} {
|
proc getcommits {rargs} {
|
||||||
global commits commfd phase canv mainfont
|
global commits commfd phase canv mainfont env
|
||||||
global startmsecs nextupdate
|
global startmsecs nextupdate
|
||||||
global ctext maincursor textcursor leftover
|
global ctext maincursor textcursor leftover
|
||||||
|
|
||||||
|
# check that we can find a .git directory somewhere...
|
||||||
|
if {[info exists env(GIT_DIR)]} {
|
||||||
|
set gitdir $env(GIT_DIR)
|
||||||
|
} else {
|
||||||
|
set gitdir ".git"
|
||||||
|
}
|
||||||
|
if {![file isdirectory $gitdir]} {
|
||||||
|
error_popup "Cannot find the git directory \"$gitdir\"."
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
set commits {}
|
set commits {}
|
||||||
set phase getcommits
|
set phase getcommits
|
||||||
set startmsecs [clock clicks -milliseconds]
|
set startmsecs [clock clicks -milliseconds]
|
||||||
@ -73,16 +81,21 @@ to allow selection of commits to be displayed.)}
|
|||||||
while 1 {
|
while 1 {
|
||||||
set i [string first "\0" $stuff $start]
|
set i [string first "\0" $stuff $start]
|
||||||
if {$i < 0} {
|
if {$i < 0} {
|
||||||
set leftover [string range $stuff $start end]
|
append leftover [string range $stuff $start end]
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
set cmit [string range $stuff $start [expr {$i - 1}]]
|
set cmit [string range $stuff $start [expr {$i - 1}]]
|
||||||
if {$start == 0} {
|
if {$start == 0} {
|
||||||
set cmit "$leftover$cmit"
|
set cmit "$leftover$cmit"
|
||||||
|
set leftover {}
|
||||||
}
|
}
|
||||||
set start [expr {$i + 1}]
|
set start [expr {$i + 1}]
|
||||||
if {![regexp {^([0-9a-f]{40})\n} $cmit match id]} {
|
if {![regexp {^([0-9a-f]{40})\n} $cmit match id]} {
|
||||||
error_popup "Can't parse git-rev-list output: {$cmit}"
|
set shortcmit $cmit
|
||||||
|
if {[string length $shortcmit] > 80} {
|
||||||
|
set shortcmit "[string range $shortcmit 0 80]..."
|
||||||
|
}
|
||||||
|
error_popup "Can't parse git-rev-list output: {$shortcmit}"
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
set cmit [string range $cmit 41 end]
|
set cmit [string range $cmit 41 end]
|
||||||
@ -260,7 +273,7 @@ proc makewindow {} {
|
|||||||
global findtype findloc findstring fstring geometry
|
global findtype findloc findstring fstring geometry
|
||||||
global entries sha1entry sha1string sha1but
|
global entries sha1entry sha1string sha1but
|
||||||
global maincursor textcursor
|
global maincursor textcursor
|
||||||
global linectxmenu
|
global rowctxmenu
|
||||||
|
|
||||||
menu .bar
|
menu .bar
|
||||||
.bar add cascade -label "File" -menu .bar.file
|
.bar add cascade -label "File" -menu .bar.file
|
||||||
@ -366,8 +379,8 @@ proc makewindow {} {
|
|||||||
|
|
||||||
pack .ctop -side top -fill both -expand 1
|
pack .ctop -side top -fill both -expand 1
|
||||||
|
|
||||||
bindall <1> {selcanvline %x %y}
|
bindall <1> {selcanvline %W %x %y}
|
||||||
bindall <B1-Motion> {selcanvline %x %y}
|
#bindall <B1-Motion> {selcanvline %W %x %y}
|
||||||
bindall <ButtonRelease-4> "allcanvs yview scroll -5 units"
|
bindall <ButtonRelease-4> "allcanvs yview scroll -5 units"
|
||||||
bindall <ButtonRelease-5> "allcanvs yview scroll 5 units"
|
bindall <ButtonRelease-5> "allcanvs yview scroll 5 units"
|
||||||
bindall <2> "allcanvs scan mark 0 %y"
|
bindall <2> "allcanvs scan mark 0 %y"
|
||||||
@ -400,13 +413,19 @@ proc makewindow {} {
|
|||||||
bind . <Button-1> "click %W"
|
bind . <Button-1> "click %W"
|
||||||
bind $fstring <Key-Return> dofind
|
bind $fstring <Key-Return> dofind
|
||||||
bind $sha1entry <Key-Return> gotocommit
|
bind $sha1entry <Key-Return> gotocommit
|
||||||
|
bind $sha1entry <<PasteSelection>> clearsha1
|
||||||
|
|
||||||
set maincursor [. cget -cursor]
|
set maincursor [. cget -cursor]
|
||||||
set textcursor [$ctext cget -cursor]
|
set textcursor [$ctext cget -cursor]
|
||||||
|
|
||||||
set linectxmenu .linectxmenu
|
set rowctxmenu .rowctxmenu
|
||||||
menu $linectxmenu -tearoff 0
|
menu $rowctxmenu -tearoff 0
|
||||||
$linectxmenu add command -label "Select" -command lineselect
|
$rowctxmenu add command -label "Diff this -> selected" \
|
||||||
|
-command {diffvssel 0}
|
||||||
|
$rowctxmenu add command -label "Diff selected -> this" \
|
||||||
|
-command {diffvssel 1}
|
||||||
|
$rowctxmenu add command -label "Make patch" -command mkpatch
|
||||||
|
$rowctxmenu add command -label "Create tag" -command mktag
|
||||||
}
|
}
|
||||||
|
|
||||||
# when we make a key binding for the toplevel, make sure
|
# when we make a key binding for the toplevel, make sure
|
||||||
@ -536,13 +555,11 @@ proc about {} {
|
|||||||
toplevel $w
|
toplevel $w
|
||||||
wm title $w "About gitk"
|
wm title $w "About gitk"
|
||||||
message $w.m -text {
|
message $w.m -text {
|
||||||
Gitk version 1.1
|
Gitk version 1.2
|
||||||
|
|
||||||
Copyright © 2005 Paul Mackerras
|
Copyright © 2005 Paul Mackerras
|
||||||
|
|
||||||
Use and redistribute under the terms of the GNU General Public License
|
Use and redistribute under the terms of the GNU General Public License} \
|
||||||
|
|
||||||
(CVS $Revision: 1.24 $)} \
|
|
||||||
-justify center -aspect 400
|
-justify center -aspect 400
|
||||||
pack $w.m -side top -fill x -padx 20 -pady 20
|
pack $w.m -side top -fill x -padx 20 -pady 20
|
||||||
button $w.ok -text Close -command "destroy $w"
|
button $w.ok -text Close -command "destroy $w"
|
||||||
@ -641,10 +658,10 @@ proc initgraph {} {
|
|||||||
proc bindline {t id} {
|
proc bindline {t id} {
|
||||||
global canv
|
global canv
|
||||||
|
|
||||||
$canv bind $t <Button-3> "linemenu %X %Y $id"
|
|
||||||
$canv bind $t <Enter> "lineenter %x %y $id"
|
$canv bind $t <Enter> "lineenter %x %y $id"
|
||||||
$canv bind $t <Motion> "linemotion %x %y $id"
|
$canv bind $t <Motion> "linemotion %x %y $id"
|
||||||
$canv bind $t <Leave> "lineleave $id"
|
$canv bind $t <Leave> "lineleave $id"
|
||||||
|
$canv bind $t <Button-1> "lineclick %x %y $id"
|
||||||
}
|
}
|
||||||
|
|
||||||
proc drawcommitline {level} {
|
proc drawcommitline {level} {
|
||||||
@ -655,7 +672,7 @@ proc drawcommitline {level} {
|
|||||||
global oldlevel oldnlines oldtodo
|
global oldlevel oldnlines oldtodo
|
||||||
global idtags idline idheads
|
global idtags idline idheads
|
||||||
global lineno lthickness mainline sidelines
|
global lineno lthickness mainline sidelines
|
||||||
global commitlisted
|
global commitlisted rowtextx idpos
|
||||||
|
|
||||||
incr numcommits
|
incr numcommits
|
||||||
incr lineno
|
incr lineno
|
||||||
@ -710,10 +727,33 @@ proc drawcommitline {level} {
|
|||||||
[expr $x + $orad - 1] [expr $y1 + $orad - 1] \
|
[expr $x + $orad - 1] [expr $y1 + $orad - 1] \
|
||||||
-fill $ofill -outline black -width 1]
|
-fill $ofill -outline black -width 1]
|
||||||
$canv raise $t
|
$canv raise $t
|
||||||
|
$canv bind $t <1> {selcanvline {} %x %y}
|
||||||
set xt [expr $canvx0 + [llength $todo] * $linespc]
|
set xt [expr $canvx0 + [llength $todo] * $linespc]
|
||||||
if {[llength $currentparents] > 2} {
|
if {[llength $currentparents] > 2} {
|
||||||
set xt [expr {$xt + ([llength $currentparents] - 2) * $linespc}]
|
set xt [expr {$xt + ([llength $currentparents] - 2) * $linespc}]
|
||||||
}
|
}
|
||||||
|
set rowtextx($lineno) $xt
|
||||||
|
set idpos($id) [list $x $xt $y1]
|
||||||
|
if {[info exists idtags($id)] || [info exists idheads($id)]} {
|
||||||
|
set xt [drawtags $id $x $xt $y1]
|
||||||
|
}
|
||||||
|
set headline [lindex $commitinfo($id) 0]
|
||||||
|
set name [lindex $commitinfo($id) 1]
|
||||||
|
set date [lindex $commitinfo($id) 2]
|
||||||
|
set linehtag($lineno) [$canv create text $xt $y1 -anchor w \
|
||||||
|
-text $headline -font $mainfont ]
|
||||||
|
$canv bind $linehtag($lineno) <Button-3> "rowmenu %X %Y $id"
|
||||||
|
set linentag($lineno) [$canv2 create text 3 $y1 -anchor w \
|
||||||
|
-text $name -font $namefont]
|
||||||
|
set linedtag($lineno) [$canv3 create text 3 $y1 -anchor w \
|
||||||
|
-text $date -font $mainfont]
|
||||||
|
}
|
||||||
|
|
||||||
|
proc drawtags {id x xt y1} {
|
||||||
|
global idtags idheads
|
||||||
|
global linespc lthickness
|
||||||
|
global canv mainfont
|
||||||
|
|
||||||
set marks {}
|
set marks {}
|
||||||
set ntags 0
|
set ntags 0
|
||||||
if {[info exists idtags($id)]} {
|
if {[info exists idtags($id)]} {
|
||||||
@ -723,48 +763,42 @@ proc drawcommitline {level} {
|
|||||||
if {[info exists idheads($id)]} {
|
if {[info exists idheads($id)]} {
|
||||||
set marks [concat $marks $idheads($id)]
|
set marks [concat $marks $idheads($id)]
|
||||||
}
|
}
|
||||||
if {$marks != {}} {
|
if {$marks eq {}} {
|
||||||
set delta [expr {int(0.5 * ($linespc - $lthickness))}]
|
return $xt
|
||||||
set yt [expr $y1 - 0.5 * $linespc]
|
|
||||||
set yb [expr $yt + $linespc - 1]
|
|
||||||
set xvals {}
|
|
||||||
set wvals {}
|
|
||||||
foreach tag $marks {
|
|
||||||
set wid [font measure $mainfont $tag]
|
|
||||||
lappend xvals $xt
|
|
||||||
lappend wvals $wid
|
|
||||||
set xt [expr {$xt + $delta + $wid + $lthickness + $linespc}]
|
|
||||||
}
|
|
||||||
set t [$canv create line $x $y1 [lindex $xvals end] $y1 \
|
|
||||||
-width $lthickness -fill black]
|
|
||||||
$canv lower $t
|
|
||||||
foreach tag $marks x $xvals wid $wvals {
|
|
||||||
set xl [expr $x + $delta]
|
|
||||||
set xr [expr $x + $delta + $wid + $lthickness]
|
|
||||||
if {[incr ntags -1] >= 0} {
|
|
||||||
# draw a tag
|
|
||||||
$canv create polygon $x [expr $yt + $delta] $xl $yt\
|
|
||||||
$xr $yt $xr $yb $xl $yb $x [expr $yb - $delta] \
|
|
||||||
-width 1 -outline black -fill yellow
|
|
||||||
} else {
|
|
||||||
# draw a head
|
|
||||||
set xl [expr $xl - $delta/2]
|
|
||||||
$canv create polygon $x $yt $xr $yt $xr $yb $x $yb \
|
|
||||||
-width 1 -outline black -fill green
|
|
||||||
}
|
|
||||||
$canv create text $xl $y1 -anchor w -text $tag \
|
|
||||||
-font $mainfont
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
set headline [lindex $commitinfo($id) 0]
|
|
||||||
set name [lindex $commitinfo($id) 1]
|
set delta [expr {int(0.5 * ($linespc - $lthickness))}]
|
||||||
set date [lindex $commitinfo($id) 2]
|
set yt [expr $y1 - 0.5 * $linespc]
|
||||||
set linehtag($lineno) [$canv create text $xt $y1 -anchor w \
|
set yb [expr $yt + $linespc - 1]
|
||||||
-text $headline -font $mainfont ]
|
set xvals {}
|
||||||
set linentag($lineno) [$canv2 create text 3 $y1 -anchor w \
|
set wvals {}
|
||||||
-text $name -font $namefont]
|
foreach tag $marks {
|
||||||
set linedtag($lineno) [$canv3 create text 3 $y1 -anchor w \
|
set wid [font measure $mainfont $tag]
|
||||||
-text $date -font $mainfont]
|
lappend xvals $xt
|
||||||
|
lappend wvals $wid
|
||||||
|
set xt [expr {$xt + $delta + $wid + $lthickness + $linespc}]
|
||||||
|
}
|
||||||
|
set t [$canv create line $x $y1 [lindex $xvals end] $y1 \
|
||||||
|
-width $lthickness -fill black -tags tag.$id]
|
||||||
|
$canv lower $t
|
||||||
|
foreach tag $marks x $xvals wid $wvals {
|
||||||
|
set xl [expr $x + $delta]
|
||||||
|
set xr [expr $x + $delta + $wid + $lthickness]
|
||||||
|
if {[incr ntags -1] >= 0} {
|
||||||
|
# draw a tag
|
||||||
|
$canv create polygon $x [expr $yt + $delta] $xl $yt\
|
||||||
|
$xr $yt $xr $yb $xl $yb $x [expr $yb - $delta] \
|
||||||
|
-width 1 -outline black -fill yellow -tags tag.$id
|
||||||
|
} else {
|
||||||
|
# draw a head
|
||||||
|
set xl [expr $xl - $delta/2]
|
||||||
|
$canv create polygon $x $yt $xr $yt $xr $yb $x $yb \
|
||||||
|
-width 1 -outline black -fill green -tags tag.$id
|
||||||
|
}
|
||||||
|
$canv create text $xl $y1 -anchor w -text $tag \
|
||||||
|
-font $mainfont -tags tag.$id
|
||||||
|
}
|
||||||
|
return $xt
|
||||||
}
|
}
|
||||||
|
|
||||||
proc updatetodo {level noshortcut} {
|
proc updatetodo {level noshortcut} {
|
||||||
@ -881,11 +915,11 @@ proc drawslants {} {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
proc decidenext {} {
|
proc decidenext {{noread 0}} {
|
||||||
global parents children nchildren ncleft todo
|
global parents children nchildren ncleft todo
|
||||||
global canv canv2 canv3 mainfont namefont canvx0 canvy linespc
|
global canv canv2 canv3 mainfont namefont canvx0 canvy linespc
|
||||||
global datemode cdate
|
global datemode cdate
|
||||||
global lineid linehtag linentag linedtag commitinfo
|
global commitinfo
|
||||||
global currentparents oldlevel oldnlines oldtodo
|
global currentparents oldlevel oldnlines oldtodo
|
||||||
global lineno lthickness
|
global lineno lthickness
|
||||||
|
|
||||||
@ -903,6 +937,12 @@ proc decidenext {} {
|
|||||||
set p [lindex $todo $k]
|
set p [lindex $todo $k]
|
||||||
if {$ncleft($p) == 0} {
|
if {$ncleft($p) == 0} {
|
||||||
if {$datemode} {
|
if {$datemode} {
|
||||||
|
if {![info exists commitinfo($p)]} {
|
||||||
|
if {$noread} {
|
||||||
|
return {}
|
||||||
|
}
|
||||||
|
readcommit $p
|
||||||
|
}
|
||||||
if {$latest == {} || $cdate($p) > $latest} {
|
if {$latest == {} || $cdate($p) > $latest} {
|
||||||
set level $k
|
set level $k
|
||||||
set latest $cdate($p)
|
set latest $cdate($p)
|
||||||
@ -963,15 +1003,16 @@ proc drawcommit {id} {
|
|||||||
lappend todo $id
|
lappend todo $id
|
||||||
lappend startcommits $id
|
lappend startcommits $id
|
||||||
}
|
}
|
||||||
set level [decidenext]
|
set level [decidenext 1]
|
||||||
if {$id != [lindex $todo $level]} {
|
if {$level == {} || $id != [lindex $todo $level]} {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
while 1 {
|
while 1 {
|
||||||
drawslants
|
drawslants
|
||||||
drawcommitline $level
|
drawcommitline $level
|
||||||
if {[updatetodo $level $datemode]} {
|
if {[updatetodo $level $datemode]} {
|
||||||
set level [decidenext]
|
set level [decidenext 1]
|
||||||
|
if {$level == {}} break
|
||||||
}
|
}
|
||||||
set id [lindex $todo $level]
|
set id [lindex $todo $level]
|
||||||
if {![info exists commitlisted($id)]} {
|
if {![info exists commitlisted($id)]} {
|
||||||
@ -988,18 +1029,18 @@ proc drawcommit {id} {
|
|||||||
proc finishcommits {} {
|
proc finishcommits {} {
|
||||||
global phase
|
global phase
|
||||||
global startcommits
|
global startcommits
|
||||||
global ctext maincursor textcursor
|
global canv mainfont ctext maincursor textcursor
|
||||||
|
|
||||||
if {$phase != "incrdraw"} {
|
if {$phase != "incrdraw"} {
|
||||||
$canv delete all
|
$canv delete all
|
||||||
$canv create text 3 3 -anchor nw -text "No commits selected" \
|
$canv create text 3 3 -anchor nw -text "No commits selected" \
|
||||||
-font $mainfont -tags textitems
|
-font $mainfont -tags textitems
|
||||||
set phase {}
|
set phase {}
|
||||||
return
|
} else {
|
||||||
|
drawslants
|
||||||
|
set level [decidenext]
|
||||||
|
drawrest $level [llength $startcommits]
|
||||||
}
|
}
|
||||||
drawslants
|
|
||||||
set level [decidenext]
|
|
||||||
drawrest $level [llength $startcommits]
|
|
||||||
. config -cursor $maincursor
|
. config -cursor $maincursor
|
||||||
$ctext config -cursor $textcursor
|
$ctext config -cursor $textcursor
|
||||||
}
|
}
|
||||||
@ -1218,9 +1259,9 @@ proc unmarkmatches {} {
|
|||||||
catch {unset matchinglines}
|
catch {unset matchinglines}
|
||||||
}
|
}
|
||||||
|
|
||||||
proc selcanvline {x y} {
|
proc selcanvline {w x y} {
|
||||||
global canv canvy0 ctext linespc selectedline
|
global canv canvy0 ctext linespc selectedline
|
||||||
global lineid linehtag linentag linedtag
|
global lineid linehtag linentag linedtag rowtextx
|
||||||
set ymax [lindex [$canv cget -scrollregion] 3]
|
set ymax [lindex [$canv cget -scrollregion] 3]
|
||||||
if {$ymax == {}} return
|
if {$ymax == {}} return
|
||||||
set yfrac [lindex [$canv yview] 0]
|
set yfrac [lindex [$canv yview] 0]
|
||||||
@ -1229,7 +1270,9 @@ proc selcanvline {x y} {
|
|||||||
if {$l < 0} {
|
if {$l < 0} {
|
||||||
set l 0
|
set l 0
|
||||||
}
|
}
|
||||||
if {[info exists selectedline] && $selectedline == $l} return
|
if {$w eq $canv} {
|
||||||
|
if {![info exists rowtextx($l)] || $x < $rowtextx($l)} return
|
||||||
|
}
|
||||||
unmarkmatches
|
unmarkmatches
|
||||||
selectline $l
|
selectline $l
|
||||||
}
|
}
|
||||||
@ -1237,8 +1280,8 @@ proc selcanvline {x y} {
|
|||||||
proc selectline {l} {
|
proc selectline {l} {
|
||||||
global canv canv2 canv3 ctext commitinfo selectedline
|
global canv canv2 canv3 ctext commitinfo selectedline
|
||||||
global lineid linehtag linentag linedtag
|
global lineid linehtag linentag linedtag
|
||||||
global canvy0 linespc nparents treepending
|
global canvy0 linespc parents nparents
|
||||||
global cflist treediffs currentid sha1entry
|
global cflist currentid sha1entry diffids
|
||||||
global commentend seenfile idtags
|
global commentend seenfile idtags
|
||||||
$canv delete hover
|
$canv delete hover
|
||||||
if {![info exists lineid($l)] || ![info exists linehtag($l)]} return
|
if {![info exists lineid($l)] || ![info exists linehtag($l)]} return
|
||||||
@ -1292,6 +1335,7 @@ proc selectline {l} {
|
|||||||
|
|
||||||
set id $lineid($l)
|
set id $lineid($l)
|
||||||
set currentid $id
|
set currentid $id
|
||||||
|
set diffids [concat $id $parents($id)]
|
||||||
$sha1entry delete 0 end
|
$sha1entry delete 0 end
|
||||||
$sha1entry insert 0 $id
|
$sha1entry insert 0 $id
|
||||||
$sha1entry selection from 0
|
$sha1entry selection from 0
|
||||||
@ -1299,6 +1343,8 @@ proc selectline {l} {
|
|||||||
|
|
||||||
$ctext conf -state normal
|
$ctext conf -state normal
|
||||||
$ctext delete 0.0 end
|
$ctext delete 0.0 end
|
||||||
|
$ctext mark set fmark.0 0.0
|
||||||
|
$ctext mark gravity fmark.0 left
|
||||||
set info $commitinfo($id)
|
set info $commitinfo($id)
|
||||||
$ctext insert end "Author: [lindex $info 1] [lindex $info 2]\n"
|
$ctext insert end "Author: [lindex $info 1] [lindex $info 2]\n"
|
||||||
$ctext insert end "Committer: [lindex $info 3] [lindex $info 4]\n"
|
$ctext insert end "Committer: [lindex $info 3] [lindex $info 4]\n"
|
||||||
@ -1318,18 +1364,25 @@ proc selectline {l} {
|
|||||||
set commentend [$ctext index "end - 1c"]
|
set commentend [$ctext index "end - 1c"]
|
||||||
|
|
||||||
$cflist delete 0 end
|
$cflist delete 0 end
|
||||||
|
$cflist insert end "Comments"
|
||||||
if {$nparents($id) == 1} {
|
if {$nparents($id) == 1} {
|
||||||
if {![info exists treediffs($id)]} {
|
startdiff
|
||||||
if {![info exists treepending]} {
|
|
||||||
gettreediffs $id
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
addtocflist $id
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
catch {unset seenfile}
|
catch {unset seenfile}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
proc startdiff {} {
|
||||||
|
global treediffs diffids treepending
|
||||||
|
|
||||||
|
if {![info exists treediffs($diffids)]} {
|
||||||
|
if {![info exists treepending]} {
|
||||||
|
gettreediffs $diffids
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
addtocflist $diffids
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
proc selnextline {dir} {
|
proc selnextline {dir} {
|
||||||
global selectedline
|
global selectedline
|
||||||
if {![info exists selectedline]} return
|
if {![info exists selectedline]} return
|
||||||
@ -1338,76 +1391,81 @@ proc selnextline {dir} {
|
|||||||
selectline $l
|
selectline $l
|
||||||
}
|
}
|
||||||
|
|
||||||
proc addtocflist {id} {
|
proc addtocflist {ids} {
|
||||||
global currentid treediffs cflist treepending
|
global diffids treediffs cflist
|
||||||
if {$id != $currentid} {
|
if {$ids != $diffids} {
|
||||||
gettreediffs $currentid
|
gettreediffs $diffids
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
$cflist insert end "All files"
|
foreach f $treediffs($ids) {
|
||||||
foreach f $treediffs($currentid) {
|
|
||||||
$cflist insert end $f
|
$cflist insert end $f
|
||||||
}
|
}
|
||||||
getblobdiffs $id
|
getblobdiffs $ids
|
||||||
}
|
}
|
||||||
|
|
||||||
proc gettreediffs {id} {
|
proc gettreediffs {ids} {
|
||||||
global treediffs parents treepending
|
global treediffs parents treepending
|
||||||
set treepending $id
|
set treepending $ids
|
||||||
set treediffs($id) {}
|
set treediffs($ids) {}
|
||||||
set p [lindex $parents($id) 0]
|
set id [lindex $ids 0]
|
||||||
|
set p [lindex $ids 1]
|
||||||
if [catch {set gdtf [open "|git-diff-tree -r $p $id" r]}] return
|
if [catch {set gdtf [open "|git-diff-tree -r $p $id" r]}] return
|
||||||
fconfigure $gdtf -blocking 0
|
fconfigure $gdtf -blocking 0
|
||||||
fileevent $gdtf readable "gettreediffline $gdtf $id"
|
fileevent $gdtf readable "gettreediffline $gdtf {$ids}"
|
||||||
}
|
}
|
||||||
|
|
||||||
proc gettreediffline {gdtf id} {
|
proc gettreediffline {gdtf ids} {
|
||||||
global treediffs treepending
|
global treediffs treepending
|
||||||
set n [gets $gdtf line]
|
set n [gets $gdtf line]
|
||||||
if {$n < 0} {
|
if {$n < 0} {
|
||||||
if {![eof $gdtf]} return
|
if {![eof $gdtf]} return
|
||||||
close $gdtf
|
close $gdtf
|
||||||
unset treepending
|
unset treepending
|
||||||
addtocflist $id
|
addtocflist $ids
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
set file [lindex $line 5]
|
set file [lindex $line 5]
|
||||||
lappend treediffs($id) $file
|
lappend treediffs($ids) $file
|
||||||
}
|
}
|
||||||
|
|
||||||
proc getblobdiffs {id} {
|
proc getblobdiffs {ids} {
|
||||||
global parents diffopts blobdifffd env curdifftag curtagstart
|
global diffopts blobdifffd env curdifftag curtagstart
|
||||||
global diffindex difffilestart
|
global diffindex difffilestart nextupdate
|
||||||
set p [lindex $parents($id) 0]
|
|
||||||
|
set id [lindex $ids 0]
|
||||||
|
set p [lindex $ids 1]
|
||||||
set env(GIT_DIFF_OPTS) $diffopts
|
set env(GIT_DIFF_OPTS) $diffopts
|
||||||
if [catch {set bdf [open "|git-diff-tree -r -p $p $id" r]} err] {
|
if [catch {set bdf [open "|git-diff-tree -r -p $p $id" r]} err] {
|
||||||
puts "error getting diffs: $err"
|
puts "error getting diffs: $err"
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
fconfigure $bdf -blocking 0
|
fconfigure $bdf -blocking 0
|
||||||
set blobdifffd($id) $bdf
|
set blobdifffd($ids) $bdf
|
||||||
set curdifftag Comments
|
set curdifftag Comments
|
||||||
set curtagstart 0.0
|
set curtagstart 0.0
|
||||||
set diffindex 0
|
set diffindex 0
|
||||||
catch {unset difffilestart}
|
catch {unset difffilestart}
|
||||||
fileevent $bdf readable "getblobdiffline $bdf $id"
|
fileevent $bdf readable "getblobdiffline $bdf {$ids}"
|
||||||
|
set nextupdate [expr {[clock clicks -milliseconds] + 100}]
|
||||||
}
|
}
|
||||||
|
|
||||||
proc getblobdiffline {bdf id} {
|
proc getblobdiffline {bdf ids} {
|
||||||
global currentid blobdifffd ctext curdifftag curtagstart seenfile
|
global diffids blobdifffd ctext curdifftag curtagstart seenfile
|
||||||
global diffnexthead diffnextnote diffindex difffilestart
|
global diffnexthead diffnextnote diffindex difffilestart
|
||||||
|
global nextupdate
|
||||||
|
|
||||||
set n [gets $bdf line]
|
set n [gets $bdf line]
|
||||||
if {$n < 0} {
|
if {$n < 0} {
|
||||||
if {[eof $bdf]} {
|
if {[eof $bdf]} {
|
||||||
close $bdf
|
close $bdf
|
||||||
if {$id == $currentid && $bdf == $blobdifffd($id)} {
|
if {$ids == $diffids && $bdf == $blobdifffd($ids)} {
|
||||||
$ctext tag add $curdifftag $curtagstart end
|
$ctext tag add $curdifftag $curtagstart end
|
||||||
set seenfile($curdifftag) 1
|
set seenfile($curdifftag) 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if {$id != $currentid || $bdf != $blobdifffd($id)} {
|
if {$ids != $diffids || $bdf != $blobdifffd($ids)} {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
$ctext conf -state normal
|
$ctext conf -state normal
|
||||||
@ -1423,8 +1481,12 @@ proc getblobdiffline {bdf id} {
|
|||||||
set header "$diffnexthead ($diffnextnote)"
|
set header "$diffnexthead ($diffnextnote)"
|
||||||
unset diffnexthead
|
unset diffnexthead
|
||||||
}
|
}
|
||||||
set difffilestart($diffindex) [$ctext index "end - 1c"]
|
set here [$ctext index "end - 1c"]
|
||||||
|
set difffilestart($diffindex) $here
|
||||||
incr diffindex
|
incr diffindex
|
||||||
|
# start mark names at fmark.1 for first file
|
||||||
|
$ctext mark set fmark.$diffindex $here
|
||||||
|
$ctext mark gravity fmark.$diffindex left
|
||||||
set curdifftag "f:$fname"
|
set curdifftag "f:$fname"
|
||||||
$ctext tag delete $curdifftag
|
$ctext tag delete $curdifftag
|
||||||
set l [expr {(78 - [string length $header]) / 2}]
|
set l [expr {(78 - [string length $header]) / 2}]
|
||||||
@ -1476,6 +1538,12 @@ proc getblobdiffline {bdf id} {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
$ctext conf -state disabled
|
$ctext conf -state disabled
|
||||||
|
if {[clock clicks -milliseconds] >= $nextupdate} {
|
||||||
|
incr nextupdate 100
|
||||||
|
fileevent $bdf readable {}
|
||||||
|
update
|
||||||
|
fileevent $bdf readable "getblobdiffline $bdf {$ids}"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
proc nextfile {} {
|
proc nextfile {} {
|
||||||
@ -1492,27 +1560,10 @@ proc nextfile {} {
|
|||||||
proc listboxsel {} {
|
proc listboxsel {} {
|
||||||
global ctext cflist currentid treediffs seenfile
|
global ctext cflist currentid treediffs seenfile
|
||||||
if {![info exists currentid]} return
|
if {![info exists currentid]} return
|
||||||
set sel [$cflist curselection]
|
set sel [lsort [$cflist curselection]]
|
||||||
if {$sel == {} || [lsearch -exact $sel 0] >= 0} {
|
if {$sel eq {}} return
|
||||||
# show everything
|
set first [lindex $sel 0]
|
||||||
$ctext tag conf Comments -elide 0
|
catch {$ctext yview fmark.$first}
|
||||||
foreach f $treediffs($currentid) {
|
|
||||||
if [info exists seenfile(f:$f)] {
|
|
||||||
$ctext tag conf "f:$f" -elide 0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
# just show selected files
|
|
||||||
$ctext tag conf Comments -elide 1
|
|
||||||
set i 1
|
|
||||||
foreach f $treediffs($currentid) {
|
|
||||||
set elide [expr {[lsearch -exact $sel $i] < 0}]
|
|
||||||
if [info exists seenfile(f:$f)] {
|
|
||||||
$ctext tag conf "f:$f" -elide $elide
|
|
||||||
}
|
|
||||||
incr i
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
proc setcoords {} {
|
proc setcoords {} {
|
||||||
@ -1554,6 +1605,13 @@ proc incrfont {inc} {
|
|||||||
redisplay
|
redisplay
|
||||||
}
|
}
|
||||||
|
|
||||||
|
proc clearsha1 {} {
|
||||||
|
global sha1entry sha1string
|
||||||
|
if {[string length $sha1string] == 40} {
|
||||||
|
$sha1entry delete 0 end
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
proc sha1change {n1 n2 op} {
|
proc sha1change {n1 n2 op} {
|
||||||
global sha1string currentid sha1but
|
global sha1string currentid sha1but
|
||||||
if {$sha1string == {}
|
if {$sha1string == {}
|
||||||
@ -1591,19 +1649,6 @@ proc gotocommit {} {
|
|||||||
error_popup "$type $sha1string is not known"
|
error_popup "$type $sha1string is not known"
|
||||||
}
|
}
|
||||||
|
|
||||||
proc linemenu {x y id} {
|
|
||||||
global linectxmenu linemenuid
|
|
||||||
set linemenuid $id
|
|
||||||
$linectxmenu post $x $y
|
|
||||||
}
|
|
||||||
|
|
||||||
proc lineselect {} {
|
|
||||||
global linemenuid idline
|
|
||||||
if {[info exists linemenuid] && [info exists idline($linemenuid)]} {
|
|
||||||
selectline $idline($linemenuid)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
proc lineenter {x y id} {
|
proc lineenter {x y id} {
|
||||||
global hoverx hovery hoverid hovertimer
|
global hoverx hovery hoverid hovertimer
|
||||||
global commitinfo canv
|
global commitinfo canv
|
||||||
@ -1667,6 +1712,268 @@ proc linehover {} {
|
|||||||
$canv raise $t
|
$canv raise $t
|
||||||
}
|
}
|
||||||
|
|
||||||
|
proc lineclick {x y id} {
|
||||||
|
global ctext commitinfo children cflist canv
|
||||||
|
|
||||||
|
unmarkmatches
|
||||||
|
$canv delete hover
|
||||||
|
# fill the details pane with info about this line
|
||||||
|
$ctext conf -state normal
|
||||||
|
$ctext delete 0.0 end
|
||||||
|
$ctext insert end "Parent:\n "
|
||||||
|
catch {destroy $ctext.$id}
|
||||||
|
button $ctext.$id -text "Go:" -command "selbyid $id" \
|
||||||
|
-padx 4 -pady 0
|
||||||
|
$ctext window create end -window $ctext.$id -align center
|
||||||
|
set info $commitinfo($id)
|
||||||
|
$ctext insert end "\t[lindex $info 0]\n"
|
||||||
|
$ctext insert end "\tAuthor:\t[lindex $info 1]\n"
|
||||||
|
$ctext insert end "\tDate:\t[lindex $info 2]\n"
|
||||||
|
$ctext insert end "\tID:\t$id\n"
|
||||||
|
if {[info exists children($id)]} {
|
||||||
|
$ctext insert end "\nChildren:"
|
||||||
|
foreach child $children($id) {
|
||||||
|
$ctext insert end "\n "
|
||||||
|
catch {destroy $ctext.$child}
|
||||||
|
button $ctext.$child -text "Go:" -command "selbyid $child" \
|
||||||
|
-padx 4 -pady 0
|
||||||
|
$ctext window create end -window $ctext.$child -align center
|
||||||
|
set info $commitinfo($child)
|
||||||
|
$ctext insert end "\t[lindex $info 0]"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$ctext conf -state disabled
|
||||||
|
|
||||||
|
$cflist delete 0 end
|
||||||
|
}
|
||||||
|
|
||||||
|
proc selbyid {id} {
|
||||||
|
global idline
|
||||||
|
if {[info exists idline($id)]} {
|
||||||
|
selectline $idline($id)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
proc mstime {} {
|
||||||
|
global startmstime
|
||||||
|
if {![info exists startmstime]} {
|
||||||
|
set startmstime [clock clicks -milliseconds]
|
||||||
|
}
|
||||||
|
return [format "%.3f" [expr {([clock click -milliseconds] - $startmstime) / 1000.0}]]
|
||||||
|
}
|
||||||
|
|
||||||
|
proc rowmenu {x y id} {
|
||||||
|
global rowctxmenu idline selectedline rowmenuid
|
||||||
|
|
||||||
|
if {![info exists selectedline] || $idline($id) eq $selectedline} {
|
||||||
|
set state disabled
|
||||||
|
} else {
|
||||||
|
set state normal
|
||||||
|
}
|
||||||
|
$rowctxmenu entryconfigure 0 -state $state
|
||||||
|
$rowctxmenu entryconfigure 1 -state $state
|
||||||
|
$rowctxmenu entryconfigure 2 -state $state
|
||||||
|
set rowmenuid $id
|
||||||
|
tk_popup $rowctxmenu $x $y
|
||||||
|
}
|
||||||
|
|
||||||
|
proc diffvssel {dirn} {
|
||||||
|
global rowmenuid selectedline lineid
|
||||||
|
global ctext cflist
|
||||||
|
global diffids commitinfo
|
||||||
|
|
||||||
|
if {![info exists selectedline]} return
|
||||||
|
if {$dirn} {
|
||||||
|
set oldid $lineid($selectedline)
|
||||||
|
set newid $rowmenuid
|
||||||
|
} else {
|
||||||
|
set oldid $rowmenuid
|
||||||
|
set newid $lineid($selectedline)
|
||||||
|
}
|
||||||
|
$ctext conf -state normal
|
||||||
|
$ctext delete 0.0 end
|
||||||
|
$ctext mark set fmark.0 0.0
|
||||||
|
$ctext mark gravity fmark.0 left
|
||||||
|
$cflist delete 0 end
|
||||||
|
$cflist insert end "Top"
|
||||||
|
$ctext insert end "From $oldid\n "
|
||||||
|
$ctext insert end [lindex $commitinfo($oldid) 0]
|
||||||
|
$ctext insert end "\n\nTo $newid\n "
|
||||||
|
$ctext insert end [lindex $commitinfo($newid) 0]
|
||||||
|
$ctext insert end "\n"
|
||||||
|
$ctext conf -state disabled
|
||||||
|
$ctext tag delete Comments
|
||||||
|
$ctext tag remove found 1.0 end
|
||||||
|
set diffids [list $newid $oldid]
|
||||||
|
startdiff
|
||||||
|
}
|
||||||
|
|
||||||
|
proc mkpatch {} {
|
||||||
|
global rowmenuid currentid commitinfo patchtop patchnum
|
||||||
|
|
||||||
|
if {![info exists currentid]} return
|
||||||
|
set oldid $currentid
|
||||||
|
set oldhead [lindex $commitinfo($oldid) 0]
|
||||||
|
set newid $rowmenuid
|
||||||
|
set newhead [lindex $commitinfo($newid) 0]
|
||||||
|
set top .patch
|
||||||
|
set patchtop $top
|
||||||
|
catch {destroy $top}
|
||||||
|
toplevel $top
|
||||||
|
label $top.title -text "Generate patch"
|
||||||
|
grid $top.title -
|
||||||
|
label $top.from -text "From:"
|
||||||
|
entry $top.fromsha1 -width 40
|
||||||
|
$top.fromsha1 insert 0 $oldid
|
||||||
|
$top.fromsha1 conf -state readonly
|
||||||
|
grid $top.from $top.fromsha1 -sticky w
|
||||||
|
entry $top.fromhead -width 60
|
||||||
|
$top.fromhead insert 0 $oldhead
|
||||||
|
$top.fromhead conf -state readonly
|
||||||
|
grid x $top.fromhead -sticky w
|
||||||
|
label $top.to -text "To:"
|
||||||
|
entry $top.tosha1 -width 40
|
||||||
|
$top.tosha1 insert 0 $newid
|
||||||
|
$top.tosha1 conf -state readonly
|
||||||
|
grid $top.to $top.tosha1 -sticky w
|
||||||
|
entry $top.tohead -width 60
|
||||||
|
$top.tohead insert 0 $newhead
|
||||||
|
$top.tohead conf -state readonly
|
||||||
|
grid x $top.tohead -sticky w
|
||||||
|
button $top.rev -text "Reverse" -command mkpatchrev -padx 5
|
||||||
|
grid $top.rev x -pady 10
|
||||||
|
label $top.flab -text "Output file:"
|
||||||
|
entry $top.fname -width 60
|
||||||
|
$top.fname insert 0 [file normalize "patch$patchnum.patch"]
|
||||||
|
incr patchnum
|
||||||
|
grid $top.flab $top.fname -sticky w
|
||||||
|
frame $top.buts
|
||||||
|
button $top.buts.gen -text "Generate" -command mkpatchgo
|
||||||
|
button $top.buts.can -text "Cancel" -command mkpatchcan
|
||||||
|
grid $top.buts.gen $top.buts.can
|
||||||
|
grid columnconfigure $top.buts 0 -weight 1 -uniform a
|
||||||
|
grid columnconfigure $top.buts 1 -weight 1 -uniform a
|
||||||
|
grid $top.buts - -pady 10 -sticky ew
|
||||||
|
focus $top.fname
|
||||||
|
}
|
||||||
|
|
||||||
|
proc mkpatchrev {} {
|
||||||
|
global patchtop
|
||||||
|
|
||||||
|
set oldid [$patchtop.fromsha1 get]
|
||||||
|
set oldhead [$patchtop.fromhead get]
|
||||||
|
set newid [$patchtop.tosha1 get]
|
||||||
|
set newhead [$patchtop.tohead get]
|
||||||
|
foreach e [list fromsha1 fromhead tosha1 tohead] \
|
||||||
|
v [list $newid $newhead $oldid $oldhead] {
|
||||||
|
$patchtop.$e conf -state normal
|
||||||
|
$patchtop.$e delete 0 end
|
||||||
|
$patchtop.$e insert 0 $v
|
||||||
|
$patchtop.$e conf -state readonly
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
proc mkpatchgo {} {
|
||||||
|
global patchtop
|
||||||
|
|
||||||
|
set oldid [$patchtop.fromsha1 get]
|
||||||
|
set newid [$patchtop.tosha1 get]
|
||||||
|
set fname [$patchtop.fname get]
|
||||||
|
if {[catch {exec git-diff-tree -p $oldid $newid >$fname &} err]} {
|
||||||
|
error_popup "Error creating patch: $err"
|
||||||
|
}
|
||||||
|
catch {destroy $patchtop}
|
||||||
|
unset patchtop
|
||||||
|
}
|
||||||
|
|
||||||
|
proc mkpatchcan {} {
|
||||||
|
global patchtop
|
||||||
|
|
||||||
|
catch {destroy $patchtop}
|
||||||
|
unset patchtop
|
||||||
|
}
|
||||||
|
|
||||||
|
proc mktag {} {
|
||||||
|
global rowmenuid mktagtop commitinfo
|
||||||
|
|
||||||
|
set top .maketag
|
||||||
|
set mktagtop $top
|
||||||
|
catch {destroy $top}
|
||||||
|
toplevel $top
|
||||||
|
label $top.title -text "Create tag"
|
||||||
|
grid $top.title -
|
||||||
|
label $top.id -text "ID:"
|
||||||
|
entry $top.sha1 -width 40
|
||||||
|
$top.sha1 insert 0 $rowmenuid
|
||||||
|
$top.sha1 conf -state readonly
|
||||||
|
grid $top.id $top.sha1 -sticky w
|
||||||
|
entry $top.head -width 40
|
||||||
|
$top.head insert 0 [lindex $commitinfo($rowmenuid) 0]
|
||||||
|
$top.head conf -state readonly
|
||||||
|
grid x $top.head -sticky w
|
||||||
|
label $top.tlab -text "Tag name:"
|
||||||
|
entry $top.tag -width 40
|
||||||
|
grid $top.tlab $top.tag -sticky w
|
||||||
|
frame $top.buts
|
||||||
|
button $top.buts.gen -text "Create" -command mktaggo
|
||||||
|
button $top.buts.can -text "Cancel" -command mktagcan
|
||||||
|
grid $top.buts.gen $top.buts.can
|
||||||
|
grid columnconfigure $top.buts 0 -weight 1 -uniform a
|
||||||
|
grid columnconfigure $top.buts 1 -weight 1 -uniform a
|
||||||
|
grid $top.buts - -pady 10 -sticky ew
|
||||||
|
focus $top.tag
|
||||||
|
}
|
||||||
|
|
||||||
|
proc domktag {} {
|
||||||
|
global mktagtop env tagids idtags
|
||||||
|
global idpos idline linehtag canv selectedline
|
||||||
|
|
||||||
|
set id [$mktagtop.sha1 get]
|
||||||
|
set tag [$mktagtop.tag get]
|
||||||
|
if {$tag == {}} {
|
||||||
|
error_popup "No tag name specified"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if {[info exists tagids($tag)]} {
|
||||||
|
error_popup "Tag \"$tag\" already exists"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if {[catch {
|
||||||
|
set dir ".git"
|
||||||
|
if {[info exists env(GIT_DIR)]} {
|
||||||
|
set dir $env(GIT_DIR)
|
||||||
|
}
|
||||||
|
set fname [file join $dir "refs/tags" $tag]
|
||||||
|
set f [open $fname w]
|
||||||
|
puts $f $id
|
||||||
|
close $f
|
||||||
|
} err]} {
|
||||||
|
error_popup "Error creating tag: $err"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
set tagids($tag) $id
|
||||||
|
lappend idtags($id) $tag
|
||||||
|
$canv delete tag.$id
|
||||||
|
set xt [eval drawtags $id $idpos($id)]
|
||||||
|
$canv coords $linehtag($idline($id)) $xt [lindex $idpos($id) 2]
|
||||||
|
if {[info exists selectedline] && $selectedline == $idline($id)} {
|
||||||
|
selectline $selectedline
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
proc mktagcan {} {
|
||||||
|
global mktagtop
|
||||||
|
|
||||||
|
catch {destroy $mktagtop}
|
||||||
|
unset mktagtop
|
||||||
|
}
|
||||||
|
|
||||||
|
proc mktaggo {} {
|
||||||
|
domktag
|
||||||
|
mktagcan
|
||||||
|
}
|
||||||
|
|
||||||
proc doquit {} {
|
proc doquit {} {
|
||||||
global stopped
|
global stopped
|
||||||
set stopped 100
|
set stopped 100
|
||||||
@ -1705,6 +2012,7 @@ foreach arg $argv {
|
|||||||
set stopped 0
|
set stopped 0
|
||||||
set redisplaying 0
|
set redisplaying 0
|
||||||
set stuffsaved 0
|
set stuffsaved 0
|
||||||
|
set patchnum 0
|
||||||
setcoords
|
setcoords
|
||||||
makewindow
|
makewindow
|
||||||
readrefs
|
readrefs
|
||||||
|
Loading…
x
Reference in New Issue
Block a user