diff options
Diffstat (limited to 'tests/text.test')
-rw-r--r-- | tests/text.test | 8724 |
1 files changed, 2672 insertions, 6052 deletions
diff --git a/tests/text.test b/tests/text.test index 6812855..2ca5d54 100644 --- a/tests/text.test +++ b/tests/text.test @@ -6,1470 +6,344 @@ # Copyright (c) 1998-1999 by Scriptics Corporation. # All rights reserved. -package require tcltest 2.2 +package require tcltest 2.1 eval tcltest::configure $argv tcltest::loadTestedCommands namespace import -force tcltest::test +# Create entries in the odeption database to be sure that geometry options +# like border width have predictable values. + +option add *Text.borderWidth 2 +option add *Text.highlightThickness 2 +option add *Text.font {Courier -12} + +text .t -width 20 -height 10 +pack append . .t {top expand fill} +update +.t debug on +wm geometry . {} + # The statements below reset the main window; it's needed if the window # manager is mwm to make mwm forget about a previous minimum size setting. -wm geometry . {} + wm withdraw . wm minsize . 1 1 wm positionfrom . user wm deiconify . - -test text-1.1 {configuration option: "autoseparators"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -autoseparators yes - .t cget -autoseparators -} -cleanup { - destroy .t -} -result {1} -test text-1.1b {configuration option: "autoseparators", default} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t cget -autoseparators -} -cleanup { - destroy .t -} -result {1} -test text-1.2 {configuration option: "autoseparators"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -autoseparators nah -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.3 {configuration option: "background"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -background #ff00ff - .t cget -background -} -cleanup { - destroy .t -} -result {#ff00ff} -test text-1.4 {configuration option: "background"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -background <gorp> -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.5 {configuration option: "bd"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -bd 4 - .t cget -bd -} -cleanup { - destroy .t -} -result {4} -test text-1.6 {configuration option: "bd"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -bd foo -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.7 {configuration option: "bg"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -bg blue - .t cget -bg -} -cleanup { - destroy .t -} -result {blue} -test text-1.8 {configuration option: "bg"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -bg #xx -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.9 {configuration option: "blockcursor"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -blockcursor 0 - .t cget -blockcursor -} -cleanup { - destroy .t -} -result {0} -test text-1.10 {configuration option: "blockcursor"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -blockcursor xx -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.11 {configuration option: "borderwidth"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -borderwidth 7 - .t cget -borderwidth -} -cleanup { - destroy .t -} -result {7} -test text-1.12 {configuration option: "borderwidth"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -borderwidth ++ -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.13 {configuration option: "cursor"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -cursor watch - .t cget -cursor -} -cleanup { - destroy .t -} -result {watch} -test text-1.14 {configuration option: "cursor"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -cursor lousy -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.15 {configuration option: "exportselection"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -exportselection no - .t cget -exportselection -} -cleanup { - destroy .t -} -result {0} -test text-1.16 {configuration option: "exportselection"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -exportselection maybe -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.17 {configuration option: "fg"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -fg red - .t cget -fg -} -cleanup { - destroy .t -} -result {red} -test text-1.18 {configuration option: "fg"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -fg stupid -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.19 {configuration option: "font"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -font fixed - .t cget -font -} -cleanup { - destroy .t -} -result {fixed} -test text-1.20 {configuration option: "font"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -font {} -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.21 {configuration option: "foreground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -foreground #012 - .t cget -foreground -} -cleanup { - destroy .t -} -result {#012} -test text-1.22 {configuration option: "foreground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -foreground bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.23 {configuration option: "height"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -height 5 - .t cget -height -} -cleanup { - destroy .t -} -result {5} -test text-1.24 {configuration option: "height"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -height bad -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.25 {configuration option: "highlightbackground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -highlightbackground #123 - .t cget -highlightbackground -} -cleanup { - destroy .t -} -result {#123} -test text-1.26 {configuration option: "highlightbackground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -highlightbackground bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.27 {configuration option: "highlightcolor"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -highlightcolor #234 - .t cget -highlightcolor -} -cleanup { - destroy .t -} -result {#234} -test text-1.28 {configuration option: "highlightcolor"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -highlightcolor bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.29 {configuration option: "highlightthickness"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -highlightthickness -2 - .t cget -highlightthickness -} -cleanup { - destroy .t -} -result {0} -test text-1.30 {configuration option: "highlightthickness"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -highlightthickness bad -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.31 {configuration option: "inactiveselectbackground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -inactiveselectbackground #ffff01234567 - .t cget -inactiveselectbackground -} -cleanup { - destroy .t -} -result {#ffff01234567} -test text-1.32 {configuration option: "inactiveselectbackground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -inactiveselectbackground bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.33 {configuration option: "insertbackground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertbackground green - .t cget -insertbackground -} -cleanup { - destroy .t -} -result {green} -test text-1.34 {configuration option: "insertbackground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertbackground <bogus> -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.35 {configuration option: "insertborderwidth"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertborderwidth 45 - .t cget -insertborderwidth -} -cleanup { - destroy .t -} -result {45} -test text-1.36 {configuration option: "insertborderwidth"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertborderwidth bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.37 {configuration option: "insertofftime"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertofftime 100 - .t cget -insertofftime -} -cleanup { - destroy .t -} -result {100} -test text-1.38 {configuration option: "insertofftime"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertofftime 2.4 -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.39 {configuration option: "insertontime"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertontime 47 - .t cget -insertontime -} -cleanup { - destroy .t -} -result {47} -test text-1.40 {configuration option: "insertontime"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertontime e1 -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.41 {configuration option: "insertwidth"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertwidth 2.3 - .t cget -insertwidth -} -cleanup { - destroy .t -} -result {2} -test text-1.42 {configuration option: "insertwidth"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertwidth 47d -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.43 {configuration option: "maxundo"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -maxundo 5 - .t cget -maxundo -} -cleanup { - destroy .t -} -result {5} -test text-1.43b {configuration option: "maxundo", default} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t cget -maxundo -} -cleanup { - destroy .t -} -result {0} -test text-1.44 {configuration option: "maxundo"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -maxundo noway -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.45 {configuration option: "padx"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -padx 3.4 - .t cget -padx -} -cleanup { - destroy .t -} -result {3} -test text-1.46 {configuration option: "padx"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -padx 2.4. -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.47 {configuration option: "pady"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -pady 82 - .t cget -pady -} -cleanup { - destroy .t -} -result {82} -test text-1.48 {configuration option: "pady"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -pady bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.49 {configuration option: "relief"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -relief raised - .t cget -relief -} -cleanup { - destroy .t -} -result {raised} -test text-1.50 {configuration option: "relief"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -relief bumpy -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.51 {configuration option: "selectbackground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -selectbackground #ffff01234567 - .t cget -selectbackground -} -cleanup { - destroy .t -} -result {#ffff01234567} -test text-1.52 {configuration option: "selectbackground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -selectbackground bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.53 {configuration option: "selectborderwidth"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -selectborderwidth 21 - .t cget -selectborderwidth -} -cleanup { - destroy .t -} -result {21} -test text-1.54 {configuration option: "selectborderwidth"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -selectborderwidth 3x -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.55 {configuration option: "selectforeground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -selectforeground yellow - .t cget -selectforeground -} -cleanup { - destroy .t -} -result {yellow} -test text-1.56 {configuration option: "selectforeground"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -selectforeground #12345 -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.57 {configuration option: "spacing1"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing1 20 - .t cget -spacing1 -} -cleanup { - destroy .t -} -result {20} -test text-1.58 {configuration option: "spacing1"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing1 1.3x -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.59 {configuration option: "spacing1"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing1 -5 - .t cget -spacing1 -} -cleanup { - destroy .t -} -result {0} -test text-1.60 {configuration option: "spacing1"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing1 bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.61 {configuration option: "spacing2"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing2 5 - .t cget -spacing2 -} -cleanup { - destroy .t -} -result {5} -test text-1.62 {configuration option: "spacing2"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing2 bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.63 {configuration option: "spacing2"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing2 -1 - .t cget -spacing2 -} -cleanup { - destroy .t -} -result {0} -test text-1.64 {configuration option: "spacing2"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing2 bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.65 {configuration option: "spacing3"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing3 20 - .t cget -spacing3 -} -cleanup { - destroy .t -} -result {20} -test text-1.66 {configuration option: "spacing3"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing3 bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.67 {configuration option: "spacing3"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing3 -10 - .t cget -spacing3 -} -cleanup { - destroy .t -} -result {0} -test text-1.68 {configuration option: "spacing3"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -spacing3 bogus -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.69 {configuration option: "state"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -state d - .t cget -state -} -cleanup { - destroy .t -} -result {disabled} -test text-1.70 {configuration option: "state"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -state foo -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.71 {configuration option: "tabs"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -tabs {1i 2i 3i 4i} - .t cget -tabs -} -cleanup { - destroy .t -} -result {1i 2i 3i 4i} -test text-1.72 {configuration option: "tabs"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -tabs bad_tabs -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.73 {configuration option: "tabstyle"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -tabstyle wordprocessor - .t cget -tabstyle -} -cleanup { - destroy .t -} -result {wordprocessor} -test text-1.74 {configuration option: "tabstyle"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -tabstyle garbage -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.75 {configuration option: "undo"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -undo 1 - .t cget -undo -} -cleanup { - destroy .t -} -result {1} -test text-1.75b {configuration option: "undo", default} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t cget -undo -} -cleanup { - destroy .t -} -result {0} -test text-1.76 {configuration option: "undo"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -undo eh -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.77 {configuration option: "width"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -width 73 - .t cget -width -} -cleanup { - destroy .t -} -result {73} -test text-1.78 {configuration option: "width"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -width 2.4 -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.79 {configuration option: "wrap"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -wrap w - .t cget -wrap -} -cleanup { - destroy .t -} -result {word} -test text-1.80 {configuration option: "wrap"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -wrap bad_wrap -} -cleanup { - destroy .t -} -match glob -returnCodes {error} -result {*} -test text-1.81 {text options} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -takefocus "any old thing" - .t cget -takefocus -} -cleanup { - destroy .t -} -result {any old thing} -test text-1.82 {text options} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -xscrollcommand "x scroll command" - .t configure -xscrollcommand -} -cleanup { - destroy .t -} -result {-xscrollcommand xScrollCommand ScrollCommand {} {x scroll command}} -test text-1.83 {text options} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -yscrollcommand "test command" - .t configure -yscrollcommand -} -cleanup { - destroy .t -} -result {-yscrollcommand yScrollCommand ScrollCommand {} {test command}} -test text-1.83.1 {configuration option: "insertunfocussed"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertunfocussed none - .t cget -insertunfocussed -} -cleanup { - destroy .t -} -result none -test text-1.84 {configuration option: "insertunfocussed"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertunfocussed hollow - .t cget -insertunfocussed -} -cleanup { - destroy .t -} -result hollow -test text-1.85 {configuration option: "insertunfocussed"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -body { - .t configure -insertunfocussed solid - .t cget -insertunfocussed -} -cleanup { - destroy .t -} -result solid -test text-1.86 {configuration option: "insertunfocussed"} -setup { - text .t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} - pack .t - update -} -returnCodes error -body { - .t configure -insertunfocussed gorp -} -cleanup { - destroy .t -} -result {bad insertunfocussed "gorp": must be hollow, none, or solid} - - -test text-2.1 {Tk_TextCmd procedure} -body { - text -} -returnCodes {error} -result {wrong # args: should be "text pathName ?-option value ...?"} -test text-2.2 {Tk_TextCmd procedure} -body { - text foobar -} -returnCodes {error} -result {bad window path name "foobar"} -test text-2.3 {Tk_TextCmd procedure} -body { - text .t -gorp nofun -} -cleanup { - destroy .t -} -returnCodes {error} -result {unknown option "-gorp"} -test text-2.4 {Tk_TextCmd procedure} -body { - catch {text .t -gorp nofun} - winfo exists .t -} -cleanup { - destroy .t -} -result 0 -test text-2.5 {Tk_TextCmd procedure} -body { - text .t -bd 2 -fg red -} -cleanup { - destroy .t -} -returnCodes ok -result {.t} -test text-2.6 {Tk_TextCmd procedure} -body { - text .t -bd 2 -fg red - list [lindex [.t config -bd] 4] [lindex [.t config -fg] 4] -} -cleanup { - destroy .t -} -result {2 red} -test text-2.7 {Tk_TextCmd procedure} -constraints { - win -} -body { - catch {destroy .t} - text .t - .t tag cget sel -relief -} -cleanup { - destroy .t -} -result {flat} -test text-2.8 {Tk_TextCmd procedure} -constraints { - aqua -} -body { - catch {destroy .t} - text .t - .t tag cget sel -relief -} -cleanup { - destroy .t -} -result {flat} -test text-2.9 {Tk_TextCmd procedure} -constraints { - unix notAqua -} -body { - catch {destroy .t} - text .t - .t tag cget sel -relief -} -cleanup { - destroy .t -} -result {raised} -test text-2.10 {Tk_TextCmd procedure} -body { - list [text .t] [winfo class .t] -} -cleanup { - destroy .t -} -result {.t Text} - - -test text-3.1 {TextWidgetCmd procedure, basics} -setup { - text .t -} -body { - .t -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t option ?arg ...?"} -test text-3.2 {TextWidgetCmd procedure} -setup { - text .t -} -body { - .t gorp 1.0 z 1.2 -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad option "gorp": must be bbox, cget, compare, configure, count, debug, delete, dlineinfo, dump, edit, get, image, index, insert, mark, peer, pendingsync, replace, scan, search, see, sync, tag, window, xview, or yview} - -test text-4.1 {TextWidgetCmd procedure, "bbox" option} -setup { - text .t -} -body { - .t bbox -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t bbox index"} -test text-4.2 {TextWidgetCmd procedure, "bbox" option} -setup { - text .t -} -body { - .t bbox a b -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t bbox index"} -test text-4.3 {TextWidgetCmd procedure, "bbox" option} -setup { - text .t -} -body { - .t bbox bad_mark -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "bad_mark"} - -test text-5.1 {TextWidgetCmd procedure, "cget" option} -setup { - text .t -} -body { - .t cget -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t cget option"} -test text-5.2 {TextWidgetCmd procedure, "cget" option} -setup { - text .t -} -body { - .t cget a b -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t cget option"} -test text-5.3 {TextWidgetCmd procedure, "cget" option} -setup { - text .t -} -body { - .t cget -gorp -} -cleanup { - destroy .t -} -returnCodes {error} -result {unknown option "-gorp"} -test text-5.4 {TextWidgetCmd procedure, "cget" option} -setup { - text .t -} -body { - .t configure -bd 17 - .t cget -bd -} -cleanup { - destroy .t -} -result {17} +entry .t.e +.t.e insert end abcdefg +.t.e select from 0 -test text-6.1 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t compare a b -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t compare index1 op index2"} -test text-6.2 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t compare a b c d -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t compare index1 op index2"} -test text-6.3 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t compare @x == 1.0 -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "@x"} -test text-6.4 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t compare 1.0 < @y -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "@y"} -test text-6.5 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 +.t insert 1.0 "Line 1 abcdefghijklm 12345 Line 4 bOy GIrl .#@? x_yz !@#$% Line 7" + +catch {destroy .t2} +text .t2 +set i 0 +foreach test { + {-autoseparators yes 1 nah} + {-background #ff00ff #ff00ff <gorp>} + {-bd 4 4 foo} + {-bg blue blue #xx} + {-blockcursor 0 0 xx} + {-borderwidth 7 7 ++} + {-cursor watch watch lousy} + {-exportselection no 0 maybe} + {-fg red red stupid} + {-font fixed fixed {}} + {-foreground #012 #012 bogus} + {-height 5 5 bad} + {-highlightbackground #123 #123 bogus} + {-highlightcolor #234 #234 bogus} + {-highlightthickness -2 0 bad} + {-inactiveselectbackground #ffff01234567 #ffff01234567 bogus} + {-insertbackground green green <bogus>} + {-insertborderwidth 45 45 bogus} + {-insertofftime 100 100 2.4} + {-insertontime 47 47 e1} + {-insertwidth 2.3 2 47d} + {-maxundo 5 5 noway} + {-padx 3.4 3 2.4.} + {-pady 82 82 bogus} + {-relief raised raised bumpy} + {-selectbackground #ffff01234567 #ffff01234567 bogus} + {-selectborderwidth 21 21 3x} + {-selectforeground yellow yellow #12345} + {-spacing1 20 20 1.3x} + {-spacing1 -5 0 bogus} + {-spacing2 5 5 bogus} + {-spacing2 -1 0 bogus} + {-spacing3 20 20 bogus} + {-spacing3 -10 0 bogus} + {-state d disabled foo} + {-tabs {1i 2i 3i 4i} {1i 2i 3i 4i} bad_tabs} + {-tabstyle wordprocessor wordprocessor garbage} + {-undo 1 1 eh} + {-width 73 73 2.4} + {-wrap w word bad_wrap} +} { + test text-1.[incr i] {text options} { + set result {} + lappend result [catch {.t2 configure [lindex $test 0] [lindex $test 3]}] + .t2 configure [lindex $test 0] [lindex $test 1] + lappend result [.t2 cget [lindex $test 0]] + } [list 1 [lindex $test 2]] +} +test text-1.[incr i] {text options} { + .t2 configure -takefocus "any old thing" + .t2 cget -takefocus +} {any old thing} +test text-1.[incr i] {text options} { + .t2 configure -xscrollcommand "x scroll command" + .t2 configure -xscrollcommand +} {-xscrollcommand xScrollCommand ScrollCommand {} {x scroll command}} +test text-1.[incr i] {text options} { + .t2 configure -yscrollcommand "test command" + .t2 configure -yscrollcommand +} {-yscrollcommand yScrollCommand ScrollCommand {} {test command}} +test text-1.[incr i] {text options} { + set result {} + foreach i [.t2 configure] { + lappend result [lindex $i 4] + } + set result +} {1 blue {} {} 0 7 watch {} 0 {} fixed #012 5 #123 #234 0 #ffff01234567 green 45 100 47 2 5 3 82 raised #ffff01234567 21 yellow 0 0 0 0 {} disabled {1i 2i 3i 4i} wordprocessor {any old thing} 1 73 word {x scroll command} {test command}} + +test text-2.1 {Tk_TextCmd procedure} { + list [catch {text} msg] $msg +} {1 {wrong # args: should be "text pathName ?options?"}} +test text-2.2 {Tk_TextCmd procedure} { + list [catch {text foobar} msg] $msg +} {1 {bad window path name "foobar"}} +test text-2.3 {Tk_TextCmd procedure} { + catch {destroy .t2} + list [catch {text .t2 -gorp nofun} msg] $msg [winfo exists .t2] +} {1 {unknown option "-gorp"} 0} +test text-2.4 {Tk_TextCmd procedure} { + catch {destroy .t2} + list [catch {text .t2 -bd 2 -fg red} msg] $msg \ + [lindex [.t2 config -bd] 4] [lindex [.t2 config -fg] 4] +} {0 .t2 2 red} +if {$tcl_platform(platform) == "windows"} { + set relief flat +} elseif {[tk windowingsystem] eq "aqua"} { + set relief solid +} else { + set relief raised +} +test text-2.5 {Tk_TextCmd procedure} { + catch {destroy .t2} + text .t2 + .t2 tag cget sel -relief +} $relief +test text-2.6 {Tk_TextCmd procedure} { + catch {destroy .t2} + list [text .t2] [winfo class .t2] +} {.t2 Text} + +test text-3.1 {TextWidgetCmd procedure, basics} { + list [catch {.t} msg] $msg +} {1 {wrong # args: should be ".t option ?arg arg ...?"}} +test text-3.2 {TextWidgetCmd procedure} { + list [catch {.t gorp 1.0 z 1.2} msg] $msg +} {1 {bad option "gorp": must be bbox, cget, compare, configure, count, debug, delete, dlineinfo, dump, edit, get, image, index, insert, mark, peer, replace, scan, search, see, tag, window, xview, or yview}} + +test text-4.1 {TextWidgetCmd procedure, "bbox" option} { + list [catch {.t bbox} msg] $msg +} {1 {wrong # args: should be ".t bbox index"}} +test text-4.2 {TextWidgetCmd procedure, "bbox" option} { + list [catch {.t bbox a b} msg] $msg +} {1 {wrong # args: should be ".t bbox index"}} +test text-4.3 {TextWidgetCmd procedure, "bbox" option} { + list [catch {.t bbox bad_mark} msg] $msg +} {1 {bad text index "bad_mark"}} + +test text-5.1 {TextWidgetCmd procedure, "cget" option} { + list [catch {.t cget} msg] $msg +} {1 {wrong # args: should be ".t cget option"}} +test text-5.2 {TextWidgetCmd procedure, "cget" option} { + list [catch {.t cget a b} msg] $msg +} {1 {wrong # args: should be ".t cget option"}} +test text-5.3 {TextWidgetCmd procedure, "cget" option} { + list [catch {.t cget -gorp} msg] $msg +} {1 {unknown option "-gorp"}} +test text-5.4 {TextWidgetCmd procedure, "cget" option} { + .t configure -bd 17 + .t cget -bd +} {17} +.t configure -bd [lindex [.t configure -bd] 3] + +test text-6.1 {TextWidgetCmd procedure, "compare" option} { + list [catch {.t compare a b} msg] $msg +} {1 {wrong # args: should be ".t compare index1 op index2"}} +test text-6.2 {TextWidgetCmd procedure, "compare" option} { + list [catch {.t compare a b c d} msg] $msg +} {1 {wrong # args: should be ".t compare index1 op index2"}} +test text-6.3 {TextWidgetCmd procedure, "compare" option} { + list [catch {.t compare @x == 1.0} msg] $msg +} {1 {bad text index "@x"}} +test text-6.4 {TextWidgetCmd procedure, "compare" option} { + list [catch {.t compare 1.0 < @y} msg] $msg +} {1 {bad text index "@y"}} +test text-6.5 {TextWidgetCmd procedure, "compare" option} { list [.t compare 1.1 < 1.0] [.t compare 1.1 < 1.1] [.t compare 1.1 < 1.2] -} -cleanup { - destroy .t -} -result {0 0 1} -test text-6.6 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {0 0 1} +test text-6.6 {TextWidgetCmd procedure, "compare" option} { list [.t compare 1.1 <= 1.0] [.t compare 1.1 <= 1.1] [.t compare 1.1 <= 1.2] -} -cleanup { - destroy .t -} -result {0 1 1} -test text-6.7 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {0 1 1} +test text-6.7 {TextWidgetCmd procedure, "compare" option} { list [.t compare 1.1 == 1.0] [.t compare 1.1 == 1.1] [.t compare 1.1 == 1.2] -} -cleanup { - destroy .t -} -result {0 1 0} -test text-6.8 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {0 1 0} +test text-6.8 {TextWidgetCmd procedure, "compare" option} { list [.t compare 1.1 >= 1.0] [.t compare 1.1 >= 1.1] [.t compare 1.1 >= 1.2] -} -cleanup { - destroy .t -} -result {1 1 0} -test text-6.9 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {1 1 0} +test text-6.9 {TextWidgetCmd procedure, "compare" option} { list [.t compare 1.1 > 1.0] [.t compare 1.1 > 1.1] [.t compare 1.1 > 1.2] -} -cleanup { - destroy .t -} -result {1 0 0} -test text-6.10 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {1 0 0} +test text-6.10 {TextWidgetCmd procedure, "compare" option} { list [.t com 1.1 != 1.0] [.t compare 1.1 != 1.1] [.t compare 1.1 != 1.2] -} -cleanup { - destroy .t -} -result {1 0 1} -test text-6.11 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t compare 1.0 <x 1.2 -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad comparison operator "<x": must be <, <=, ==, >=, >, or !=} -test text-6.12 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t compare 1.0 >> 1.2 -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad comparison operator ">>": must be <, <=, ==, >=, >, or !=} -test text-6.13 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t compare 1.0 z 1.2 -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad comparison operator "z": must be <, <=, ==, >=, >, or !=} -test text-6.14 {TextWidgetCmd procedure, "compare" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t co 1.0 z 1.2 -} -cleanup { - destroy .t -} -returnCodes {error} -result {ambiguous option "co": must be bbox, cget, compare, configure, count, debug, delete, dlineinfo, dump, edit, get, image, index, insert, mark, peer, pendingsync, replace, scan, search, see, sync, tag, window, xview, or yview} +} {1 0 1} +test text-6.11 {TextWidgetCmd procedure, "compare" option} { + list [catch {.t compare 1.0 <x 1.2} msg] $msg +} {1 {bad comparison operator "<x": must be <, <=, ==, >=, >, or !=}} +test text-6.12 {TextWidgetCmd procedure, "compare" option} { + list [catch {.t compare 1.0 >> 1.2} msg] $msg +} {1 {bad comparison operator ">>": must be <, <=, ==, >=, >, or !=}} +test text-6.13 {TextWidgetCmd procedure, "compare" option} { + list [catch {.t compare 1.0 z 1.2} msg] $msg +} {1 {bad comparison operator "z": must be <, <=, ==, >=, >, or !=}} +test text-6.14 {TextWidgetCmd procedure, "compare" option} { + list [catch {.t co 1.0 z 1.2} msg] $msg +} {1 {ambiguous option "co": must be bbox, cget, compare, configure, count, debug, delete, dlineinfo, dump, edit, get, image, index, insert, mark, peer, replace, scan, search, see, tag, window, xview, or yview}} + # "configure" option is already covered above -test text-7.1 {TextWidgetCmd procedure, "debug" option} -setup { - text .t -} -body { - .t debug 0 1 -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t debug boolean"} -test text-7.2 {TextWidgetCmd procedure, "debug" option} -setup { - text .t -} -body { - .t de 0 1 -} -cleanup { - destroy .t -} -returnCodes {error} -result {ambiguous option "de": must be bbox, cget, compare, configure, count, debug, delete, dlineinfo, dump, edit, get, image, index, insert, mark, peer, pendingsync, replace, scan, search, see, sync, tag, window, xview, or yview} -test text-7.3 {TextWidgetCmd procedure, "debug" option} -setup { - text .t -} -body { +test text-7.1 {TextWidgetCmd procedure, "debug" option} { + list [catch {.t debug 0 1} msg] $msg +} {1 {wrong # args: should be ".t debug boolean"}} +test text-7.2 {TextWidgetCmd procedure, "debug" option} { + list [catch {.t de 0 1} msg] $msg +} {1 {ambiguous option "de": must be bbox, cget, compare, configure, count, debug, delete, dlineinfo, dump, edit, get, image, index, insert, mark, peer, replace, scan, search, see, tag, window, xview, or yview}} +test text-7.3 {TextWidgetCmd procedure, "debug" option} { .t debug true .t deb -} -cleanup { - destroy .t -} -result {1} -test text-7.4 {TextWidgetCmd procedure, "debug" option} -setup { - text .t -} -body { +} 1 +test text-7.4 {TextWidgetCmd procedure, "debug" option} { .t debug false .t debug -} -cleanup { - destroy .t -} -result {0} - - -test text-8.1 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { - .t delete -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t delete index1 ?index2 ...?"} -test text-8.2 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { - .t delete a b c -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "a"} -test text-8.3 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { - .t delete @x 2.2 -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "@x"} -test text-8.4 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345" - .t delete 2.3 @y -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "@y"} -test text-8.5 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} 0 +.t debug + +test text-8.1 {TextWidgetCmd procedure, "delete" option} { + list [catch {.t delete} msg] $msg +} {1 {wrong # args: should be ".t delete index1 ?index2 ...?"}} +test text-8.2 {TextWidgetCmd procedure, "delete" option} { + list [catch {.t delete a b c} msg] $msg +} {1 {bad text index "a"}} +test text-8.3 {TextWidgetCmd procedure, "delete" option} { + list [catch {.t delete @x 2.2} msg] $msg +} {1 {bad text index "@x"}} +test text-8.4 {TextWidgetCmd procedure, "delete" option} { + list [catch {.t delete 2.3 @y} msg] $msg +} {1 {bad text index "@y"}} +test text-8.5 {TextWidgetCmd procedure, "delete" option} { .t configure -state disabled .t delete 2.3 .t g 2.0 2.end -} -cleanup { - destroy .t -} -result {abcdefghijklm} -test text-8.6 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} abcdefghijklm +.t configure -state normal +test text-8.6 {TextWidgetCmd procedure, "delete" option} { .t delete 2.3 .t get 2.0 2.end -} -cleanup { - destroy .t -} -result {abcefghijklm} -test text-8.7 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} abcefghijklm +test text-8.7 {TextWidgetCmd procedure, "delete" option} { .t delete 2.1 2.3 .t get 2.0 2.end -} -cleanup { - destroy .t -} -result {adefghijklm} -test text-8.8 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345" +} aefghijklm +test text-8.8 {TextWidgetCmd procedure, "delete" option} { # All indices are checked before we actually delete anything - .t delete 2.1 2.3 foo -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "foo"} -test text-8.9 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345" -# All indices are checked before we actually delete anything - catch {.t delete 2.1 2.3 foo} - .t get 2.0 2.end -} -cleanup { - destroy .t -} -result {abcdefghijklm} -test text-8.10 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" + list [catch {.t delete 2.1 2.3 foo} msg] $msg \ + [.t get 2.0 2.end] +} {1 {bad text index "foo"} aefghijklm} +set prevtext [.t get 1.0 end-1c] +test text-8.9 {TextWidgetCmd procedure, "delete" option} { # auto-forward one byte if the last "pair" is just one - .t delete 1.0 end - .t insert 1.0 "foo\nabcdefghijklm" + .t delete 1.0 end; .t insert 1.0 "foo\nabcdefghijklm" .t delete 2.1 2.3 2.3 .t get 1.0 end-1c -} -cleanup { - destroy .t -} -result {foo -aefghijklm} -test text-8.11 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { +} foo\naefghijklm +test text-8.10 {TextWidgetCmd procedure, "delete" option} { # all indices will be ordered before deletion - .t insert 1.0 "foo\nabcdefghijklm" + .t delete 1.0 end; .t insert 1.0 "foo\nabcdefghijklm" .t delete 2.0 2.3 2.7 2.9 2.4 .t get 1.0 end-1c -} -cleanup { - destroy .t -} -result {foo -dfgjklm} -test text-8.12 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { +} foo\ndfgjklm +test text-8.11 {TextWidgetCmd procedure, "delete" option} { # and check again with even pairs - .t insert 1.0 "foo\nabcdefghijklm" + .t delete 1.0 end; .t insert 1.0 "foo\nabcdefghijklm" .t delete 2.0 2.2 2.7 2.9 2.4 2.5 .t get 1.0 end-1c -} -cleanup { - destroy .t -} -result {foo -cdfgjklm} -test text-8.13 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { +} foo\ncdfgjklm +test text-8.12 {TextWidgetCmd procedure, "delete" option} { # we should get the longest range on equal start indices - .t insert 1.0 "foo\nabcdefghijklm" + .t delete 1.0 end; .t insert 1.0 "foo\nabcdefghijklm" .t delete 2.0 2.2 2.0 2.5 2.0 2.3 2.8 2.7 .t get 1.0 end-1c -} -cleanup { - destroy .t -} -result {foo -fghijklm} -test text-8.14 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { +} foo\nfghijklm +test text-8.13 {TextWidgetCmd procedure, "delete" option} { # we should get the longest range on equal start indices - .t insert 1.0 "foo\nabcdefghijklm" + .t delete 1.0 end; .t insert 1.0 "foo\nabcdefghijklm" .t delete 2.0 2.2 1.2 2.6 2.0 2.5 .t get 1.0 end-1c -} -cleanup { - destroy .t -} -result {foghijklm} -test text-8.15 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { +} foghijklm +test text-8.14 {TextWidgetCmd procedure, "delete" option} { # we should get the longest range on equal start indices - .t insert 1.0 "foo\nabcdefghijklm" + .t delete 1.0 end; .t insert 1.0 "foo\nabcdefghijklm" .t delete 2.0 2.2 2.0 2.5 1.1 2.3 2.8 2.7 .t get 1.0 end-1c -} -cleanup { - destroy .t -} -result {ffghijklm} -test text-8.16 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { +} ffghijklm +test text-8.15 {TextWidgetCmd procedure, "delete" option} { # we should get the watch for overlapping ranges - they should # essentially be merged into one span. - .t insert 1.0 "foo\nabcdefghijklm" + .t delete 1.0 end; .t insert 1.0 "foo\nabcdefghijklm" .t delete 2.0 2.6 2.2 2.8 .t get 1.0 end-1c -} -cleanup { - destroy .t -} -result {foo -ijklm} -test text-8.17 {TextWidgetCmd procedure, "delete" option} -setup { - text .t -} -body { +} foo\nijklm +test text-8.16 {TextWidgetCmd procedure, "delete" option} { # we should get the watch for overlapping ranges - they should # essentially be merged into one span. - .t insert 1.0 "foo\nabcdefghijklm" + .t delete 1.0 end; .t insert 1.0 "foo\nabcdefghijklm" .t delete 2.0 2.6 2.2 2.4 .t get 1.0 end-1c -} -cleanup { - destroy .t -} -result {foo -ghijklm} -test text-8.18 {TextWidgetCmd procedure, "replace" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345" - .t replace 1.3 2.3 -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t replace index1 index2 chars ?tagList chars tagList ...?"} -test text-8.19 {TextWidgetCmd procedure, "replace" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345" - .t replace 3.1 2.3 foo -} -cleanup { - destroy .t -} -returnCodes {error} -result {index "2.3" before "3.1" in the text} -test text-8.20 {TextWidgetCmd procedure, "replace" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t replace 2.1 2.3 foo -} -cleanup { - destroy .t -} -returnCodes ok -result {} -test text-8.21 {TextWidgetCmd procedure, "replace" option with undo} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -abcdefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - set prevtext [.t get 1.0 end-1c] +} foo\nghijklm +.t delete 1.0 end; .t insert 1.0 $prevtext +test text-8.17 {TextWidgetCmd procedure, "replace" option} { + list [catch {.t replace 1.3 2.3} err] $err +} {1 {wrong # args: should be ".t replace index1 index2 chars ?tagList chars tagList ...?"}} +test text-8.18 {TextWidgetCmd procedure, "replace" option} { + list [catch {.t replace 3.1 2.3 foo} err] $err +} {1 {Index "2.3" before "3.1" in the text}} +test text-8.19 {TextWidgetCmd procedure, "replace" option} { + list [catch {.t replace 2.1 2.3 foo} err] $err +} {0 {}} +.t delete 1.0 end; .t insert 1.0 $prevtext +test text-8.20 {TextWidgetCmd procedure, "replace" option with undo} { .t configure -undo 0 .t configure -undo 1 # Ensure it is treated as a single undo action .t replace 2.1 2.3 foo .t edit undo + .t configure -undo 0 string equal [.t get 1.0 end-1c] $prevtext -} -cleanup { - destroy .t -} -result {1} -test text-8.22 {TextWidgetCmd procedure, "replace" option with undo} -setup { - text .t - set res {} -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {1} +test text-8.21 {TextWidgetCmd procedure, "replace" option with undo} { .t configure -undo 0 .t configure -undo 1 .t replace 2.1 2.3 foo @@ -1478,25 +352,15 @@ Line 7" # to do this, then we should be able to change this test. The # behaviour tested for here is not, strictly speaking, documented. rename .t test.t + set res {} proc .t {args} { lappend ::res $args ; uplevel 1 test.t $args } .t edit undo - return $res -} -cleanup { rename .t {} rename test.t .t - destroy .t -} -result {{edit undo} {delete 2.1 2.4} {mark set insert 2.1} {see insert} {insert 2.1 ef} {mark set insert 2.3} {see insert}} -test text-8.23 {TextWidgetCmd procedure, "replace" option with undo} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - set prevtext [.t get 1.0 end-1c] + .t configure -undo 0 + set res +} {{edit undo} {delete 2.1 2.4} {mark set insert 2.1} {see insert} {insert 2.1 ef} {mark set insert 2.3} {see insert}} +test text-8.22 {TextWidgetCmd procedure, "replace" option with undo} { .t configure -undo 0 .t configure -undo 1 # Ensure that undo (even composite undo like 'replace') @@ -1506,1145 +370,322 @@ Line 7" .t edit undo .t configure -start {} -end {} .t configure -undo 0 - string equal [.t get 1.0 end-1c] $prevtext -} -cleanup { - destroy .t -} -result {1} -test text-8.24 {TextWidgetCmd procedure, "replace" option with peers, undo} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - set prevtext [.t get 1.0 end-1c] + if {![string equal [.t get 1.0 end-1c] $prevtext]} { + set res [list [.t get 1.0 end-1c] ne $prevtext] + } else { + set res 1 + } +} {1} +.t delete 1.0 end; .t insert 1.0 $prevtext +test text-8.23 {TextWidgetCmd procedure, "replace" option with peers, undo} { .t configure -undo 0 .t configure -undo 1 .t peer create .tt -undo 1 -# Ensure that undo (even composite undo like 'replace') -# works when the the event took place in one peer, which -# is then deleted, before the undo takes place in another peer. + # Ensure that undo (even composite undo like 'replace') + # works when the the event took place in one peer, which + # is then deleted, before the undo takes place in another peer. .tt replace 2.1 2.3 foo .tt configure -start 1 -end 1 destroy .tt .t edit undo .t configure -start {} -end {} .t configure -undo 0 - string equal [.t get 1.0 end-1c] $prevtext -} -cleanup { - destroy .t -} -result {1} -test text-8.25 {TextWidgetCmd procedure, "replace" option with peers, undo} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - set prevtext [.t get 1.0 end-1c] + if {![string equal [.t get 1.0 end-1c] $prevtext]} { + set res [list [.t get 1.0 end-1c] ne $prevtext] + } else { + set res 1 + } +} {1} +.t delete 1.0 end; .t insert 1.0 $prevtext +test text-8.24 {TextWidgetCmd procedure, "replace" option with peers, undo} { .t configure -undo 0 .t configure -undo 1 .t peer create .tt -undo 1 -# Ensure that undo (even composite undo like 'replace') -# works when the the event took place in one peer, which -# is then deleted, before the undo takes place in another peer -# which isn't showing everything. + # Ensure that undo (even composite undo like 'replace') + # works when the the event took place in one peer, which + # is then deleted, before the undo takes place in another peer + # which isn't showing everything. .tt replace 2.1 2.3 foo set res [.tt get 2.1 2.4] .tt configure -start 1 -end 1 destroy .tt .t configure -start 3 -end 4 -# msg will actually be set to a silently ignored error message here, -# (that the .tt command doesn't exist), but that is not important. - lappend res [catch {.t edit undo}] + # msg will actually be set to a silently ignored error message here, + # (that the .tt command doesn't exist), but that is not important. + lappend res [catch {.t edit undo} msg] .t configure -undo 0 .t configure -start {} -end {} - lappend res [string equal [.t get 1.0 end-1c] $prevtext] -} -cleanup { - destroy .t -} -result {foo 0 1} -test text-8.26 {TextWidgetCmd procedure, "replace" option crash} -setup { - text .tt + if {![string equal [.t get 1.0 end-1c] $prevtext]} { + lappend res [list [.t get 1.0 end-1c] ne $prevtext] + } else { + lappend res 1 + } +} {foo 0 1} +test text-8.25 {TextWidgetCmd procedure, "replace" option crash} -setup { + destroy .tt } -body { + text .tt .tt insert 0.0 foo\n .tt replace end-1l end bar } -cleanup { destroy .tt } -result {} - -test text-9.1 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t get -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t get ?-displaychars? ?--? index1 ?index2 ...?"} -test text-9.2 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t get a b c -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "a"} -test text-9.3 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t get @q 3.1 -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "@q"} -test text-9.4 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t get 3.1 @r -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "@r"} -test text-9.5 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +.t delete 1.0 end; .t insert 1.0 $prevtext + +test text-9.1 {TextWidgetCmd procedure, "get" option} { + list [catch {.t get} msg] $msg +} {1 {wrong # args: should be ".t get ?-displaychars? ?--? index1 ?index2 ...?"}} +test text-9.2 {TextWidgetCmd procedure, "get" option} { + list [catch {.t get a b c} msg] $msg +} {1 {bad text index "a"}} +test text-9.3 {TextWidgetCmd procedure, "get" option} { + list [catch {.t get @q 3.1} msg] $msg +} {1 {bad text index "@q"}} +test text-9.4 {TextWidgetCmd procedure, "get" option} { + list [catch {.t get 3.1 @r} msg] $msg +} {1 {bad text index "@r"}} +test text-9.5 {TextWidgetCmd procedure, "get" option} { .t get 5.7 5.3 -} -cleanup { - destroy .t -} -result {} -test text-9.6 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {} +test text-9.6 {TextWidgetCmd procedure, "get" option} { .t get 5.3 5.5 -} -cleanup { - destroy .t -} -result { G} -test text-9.7 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} { G} +test text-9.7 {TextWidgetCmd procedure, "get" option} { .t get 5.3 end -} -cleanup { - destroy .t -} -result { GIrl .#@? x_yz +} { GIrl .#@? x_yz !@#$% Line 7 } -test text-9.8 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +.t mark set a 5.3 +.t mark set b 5.3 +.t mark set c 5.5 +test text-9.8 {TextWidgetCmd procedure, "get" option} { .t get 5.2 5.7 -} -cleanup { - destroy .t -} -result {y GIr} -test text-9.9 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {y GIr} +test text-9.9 {TextWidgetCmd procedure, "get" option} { .t get 5.2 -} -cleanup { - destroy .t -} -result {y} -test text-9.10 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {y} +test text-9.10 {TextWidgetCmd procedure, "get" option} { .t get 5.2 5.4 -} -cleanup { - destroy .t -} -result {y } -test text-9.11 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {y } +test text-9.11 {TextWidgetCmd procedure, "get" option} { .t get 5.2 5.4 5.4 -} -cleanup { - destroy .t -} -result {{y } G} -test text-9.12 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {{y } G} +test text-9.12 {TextWidgetCmd procedure, "get" option} { .t get 5.2 5.4 5.4 5.5 -} -cleanup { - destroy .t -} -result {{y } G} -test text-9.13 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {{y } G} +test text-9.13 {TextWidgetCmd procedure, "get" option} { .t get 5.2 5.4 5.5 "5.5+5c" -} -cleanup { - destroy .t -} -result {{y } {Irl .}} -test text-9.14 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {{y } {Irl .}} +test text-9.14 {TextWidgetCmd procedure, "get" option} { .t get 5.2 5.4 5.4 5.5 end-3c -} -cleanup { - destroy .t -} -result {{y } G { }} -test text-9.15 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {{y } G { }} +test text-9.15 {TextWidgetCmd procedure, "get" option} { .t get 5.2 5.4 5.4 5.5 end-3c end -} -cleanup { - destroy .t -} -result {{y } G { 7 +} {{y } G { 7 }} -test text-9.16 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +test text-9.16 {TextWidgetCmd procedure, "get" option} { .t get 5.2 5.3 5.4 5.3 -} -cleanup { - destroy .t -} -result {y} -test text-9.17 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {y} +test text-9.17 {TextWidgetCmd procedure, "get" option} { .t index "5.2 +3 indices" -} -cleanup { - destroy .t -} -result {5.5} -test text-9.18 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {5.5} +test text-9.17a {TextWidgetCmd procedure, "get" option} { .t index "5.2 +3chars" -} -cleanup { - destroy .t -} -result {5.5} -test text-9.19 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {5.5} +test text-9.17b {TextWidgetCmd procedure, "get" option} { .t index "5.2 +3displayindices" -} -cleanup { - destroy .t -} -result {5.5} -test text-9.20 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 - .t get 5.2 5.4 5.5 foo -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "foo"} -test text-9.21 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 +} {5.5} +.t tag configure elide -elide 1 +.t tag add elide 5.2 5.4 +test text-9.18 {TextWidgetCmd procedure, "get" option} { + list [catch {.t get 5.2 5.4 5.5 foo} msg] $msg +} {1 {bad text index "foo"}} +test text-9.19 {TextWidgetCmd procedure, "get" option} { .t get 5.2 5.4 5.4 5.5 end-3c end -} -cleanup { - destroy .t -} -result {{y } G { 7 +} {{y } G { 7 }} -test text-9.22 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 +test text-9.20 {TextWidgetCmd procedure, "get" option} { .t get -displaychars 5.2 5.4 5.4 5.5 end-3c end -} -cleanup { - destroy .t -} -result {{} G { 7 +} {{} G { 7 }} -test text-9.23 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 +test text-9.21 {TextWidgetCmd procedure, "get" option} { list [.t index "5.1 +4indices"] [.t index "5.1+4d indices"] -} -cleanup { - destroy .t -} -result {5.5 5.7} -test text-9.24 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 +} {5.5 5.7} +test text-9.22 {TextWidgetCmd procedure, "get" option} { list [.t index "5.1 +4a chars"] [.t index "5.1+4d chars"] -} -cleanup { - destroy .t -} -result {5.5 5.7} -test text-9.25 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 +} {5.5 5.7} +test text-9.23 {TextWidgetCmd procedure, "get" option} { list [.t index "5.5 -4indices"] [.t index "5.7-4d indices"] -} -cleanup { - destroy .t -} -result {5.1 5.1} -test text-9.26 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 +} {5.1 5.1} +test text-9.24 {TextWidgetCmd procedure, "get" option} { list [.t index "5.5 -4a chars"] [.t index "5.7-4d chars"] -} -cleanup { - destroy .t -} -result {5.1 5.1} -test text-9.27 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 - .t window create 5.4 +} {5.1 5.1} +.t window create 5.4 +test text-9.25 {TextWidgetCmd procedure, "get" option} { list [.t index "5.1 +4indices"] [.t index "5.1+4d indices"] -} -cleanup { - destroy .t -} -result {5.5 5.7} -test text-9.28 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 - .t window create 5.4 +} {5.5 5.7} +test text-9.25a {TextWidgetCmd procedure, "get" option} { list [.t index "5.1 +4a chars"] [.t index "5.1+4d chars"] -} -cleanup { - destroy .t -} -result {5.6 5.8} -test text-9.29 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 - .t window create 5.4 +} {5.6 5.8} +test text-9.26 {TextWidgetCmd procedure, "get" option} { list [.t index "5.5 -4indices"] [.t index "5.7-4d indices"] -} -cleanup { - destroy .t -} -result {5.1 5.1} -test text-9.30 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 - .t window create 5.4 +} {5.1 5.1} +test text-9.26a {TextWidgetCmd procedure, "get" option} { list [.t index "5.6 -4a chars"] [.t index "5.8-4d chars"] -} -cleanup { - destroy .t -} -result {5.1 5.1} -test text-9.31 {TextWidgetCmd procedure, "get" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 5.2 5.4 - .t window create 5.4 - .t delete 5.4 - .t tag add elide 5.5 5.6 +} {5.1 5.1} +.t delete 5.4 +.t tag add elide 5.5 5.6 +test text-9.27 {TextWidgetCmd procedure, "get" option} { .t get -displaychars 5.2 5.8 -} -cleanup { - destroy .t -} -result {Grl} - - -test text-10.1 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t count -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t count ?-option value ...? index1 index2"} -test text-10.2 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t count blah 1.0 2.0 -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad option "blah" must be -chars, -displaychars, -displayindices, -displaylines, -indices, -lines, -update, -xpixels, or -ypixels} -test text-10.3 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t count a b -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "a"} -test text-10.4 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t count @q 3.1 -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "@q"} -test text-10.5 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t count 3.1 @r -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "@r"} -test text-10.6 {TextWidgetCmd procedure, "count" option} -setup { - text .t - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" -} -body { +} {Grl} +.t tag delete elide +.t mark unset a +.t mark unset b +.t mark unset c +test text-9.2.1 {TextWidgetCmd procedure, "count" option} { + list [catch {.t count} msg] $msg +} {1 {wrong # args: should be ".t count ?options? index1 index2"}} +test text-9.2.2.1 {TextWidgetCmd procedure, "count" option} { + list [catch {.t count blah 1.0 2.0} msg] $msg +} {1 {bad option "blah" must be -chars, -displaychars, -displayindices, -displaylines, -indices, -lines, -update, -xpixels, or -ypixels}} +test text-9.2.2 {TextWidgetCmd procedure, "count" option} { + list [catch {.t count a b} msg] $msg +} {1 {bad text index "a"}} +test text-9.2.3 {TextWidgetCmd procedure, "count" option} { + list [catch {.t count @q 3.1} msg] $msg +} {1 {bad text index "@q"}} +test text-9.2.4 {TextWidgetCmd procedure, "count" option} { + list [catch {.t count 3.1 @r} msg] $msg +} {1 {bad text index "@r"}} +test text-9.2.5 {TextWidgetCmd procedure, "count" option} { .t count 5.7 5.3 -} -cleanup { - destroy .t -} -result {-4} -test text-10.7 {TextWidgetCmd procedure, "count" option} -setup { - text .t - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" -} -body { +} {-4} +test text-9.2.6 {TextWidgetCmd procedure, "count" option} { .t count 5.3 5.5 -} -cleanup { - destroy .t -} -result {2} -test text-10.8 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {2} +test text-9.2.7 {TextWidgetCmd procedure, "count" option} { .t count 5.3 end -} -cleanup { - destroy .t -} -result {29} -test text-10.9 {TextWidgetCmd procedure, "count" option} -setup { - text .t - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" -} -body { +} {29} +.t mark set a 5.3 +.t mark set b 5.3 +.t mark set c 5.5 +test text-9.2.8 {TextWidgetCmd procedure, "count" option} { .t count 5.2 5.7 -} -cleanup { - destroy .t -} -result {5} -test text-10.10 {TextWidgetCmd procedure, "count" option} -setup { - text .t - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" -} -body { +} {5} +test text-9.2.9 {TextWidgetCmd procedure, "count" option} { .t count 5.2 5.3 -} -cleanup { - destroy .t -} -result {1} -test text-10.11 {TextWidgetCmd procedure, "count" option} -setup { - text .t - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" -} -body { +} {1} +test text-9.2.10 {TextWidgetCmd procedure, "count" option} { .t count 5.2 5.4 -} -cleanup { - destroy .t -} -result {2} -test text-10.12 {TextWidgetCmd procedure, "count" option} -setup { - text .t - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" -} -body { - .t count 5.2 foo -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "foo"} -test text-10.13 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 +} {2} +test text-9.2.17 {TextWidgetCmd procedure, "count" option} { + list [catch {.t count 5.2 foo} msg] $msg +} {1 {bad text index "foo"}} +.t tag configure elide -elide 1 +.t tag add elide 2.2 3.4 +.t tag add elide 4.0 4.1 +test text-9.2.18 {TextWidgetCmd procedure, "count" option} { .t count -displayindices 2.0 3.0 -} -cleanup { - destroy .t -} -result {2} -test text-10.14 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 +} {2} +test text-9.2.19 {TextWidgetCmd procedure, "count" option} { .t count -displayindices 2.2 3.0 -} -cleanup { - destroy .t -} -result {0} -test text-10.15 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 +} {0} +test text-9.2.20 {TextWidgetCmd procedure, "count" option} { .t count -displayindices 2.0 4.2 -} -cleanup { - destroy .t -} -result {5} -test text-10.16 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 +} {5} # Create one visible and one invisible window - frame .t.w1 - frame .t.w2 +frame .t.w1 +frame .t.w2 +.t mark set a 2.2 # Creating this window here means that the elidden text -# now starts at 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 +# now starts at 2.3, but 'a' is automatically moved to 2.3 +.t window create 2.1 -window .t.w1 +.t window create 3.1 -window .t.w2 +test text-9.2.21 {TextWidgetCmd procedure, "count" option} { .t count -displayindices 2.0 3.0 -} -cleanup { - destroy .t -} -result {3} -test text-10.17 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 +} {3} +test text-9.2.22 {TextWidgetCmd procedure, "count" option} { .t count -displayindices 2.2 3.0 -} -cleanup { - destroy .t -} -result {1} -test text-10.18 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 - .t mark set a 2.2 -# Creating this window here means that the elidden text -# now starts at 2.3, but 'a' is automatically moved to 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 +} {1} +test text-9.2.23 {TextWidgetCmd procedure, "count" option} { .t count -displayindices a 3.0 -} -cleanup { - destroy .t -} -result {0} -test text-10.19 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 +} {0} +test text-9.2.24 {TextWidgetCmd procedure, "count" option} { .t count -displayindices 2.0 4.2 -} -cleanup { - destroy .t -} -result {6} -test text-10.20 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 +} {6} +test text-9.2.25 {TextWidgetCmd procedure, "count" option} { .t count -displaychars 2.0 3.0 -} -cleanup { - destroy .t -} -result {2} -test text-10.21 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 +} {2} +test text-9.2.26 {TextWidgetCmd procedure, "count" option} { .t count -displaychars 2.2 3.0 -} -cleanup { - destroy .t -} -result {1} -test text-10.22 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 - .t mark set a 2.2 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3, but 'a' is automatically moved to 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 +} {1} +test text-9.2.27 {TextWidgetCmd procedure, "count" option} { .t count -displaychars a 3.0 -} -cleanup { - destroy .t -} -result {0} -test text-10.23 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 - .t count -displaychars 2.0 4.2 -} -cleanup { - destroy .t -} -result {5} -test text-10.24 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 +} {0} +test text-9.2.28 {TextWidgetCmd procedure, "count" option} { .t count -displaychars 2.0 4.2 +} {5} +test text-9.2.29 {TextWidgetCmd procedure, "count" option} { list [.t count -indices 2.2 3.0] [.t count 2.2 3.0] -} -cleanup { - destroy .t -} -result {10 10} -test text-10.25 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 - .t mark set a 2.2 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3, but 'a' is automatically moved to 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 +} {10 10} +test text-9.2.30 {TextWidgetCmd procedure, "count" option} { list [.t count -indices a 3.0] [.t count a 3.0] -} -cleanup { - destroy .t -} -result {9 9} -test text-10.26 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 - .t count -displaychars 2.0 4.2 +} {9 9} +test text-9.2.31 {TextWidgetCmd procedure, "count" option} { .t count -indices 2.0 4.2 -} -cleanup { - destroy .t -} -result {21} -test text-10.27 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 - .t count -displaychars 2.0 4.2 +} {21} +test text-9.2.32 {TextWidgetCmd procedure, "count" option} { .t count -chars 2.2 3.0 -} -cleanup { - destroy .t -} -result {10} -test text-10.28 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 - .t mark set a 2.2 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3, but 'a' is automatically moved to 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 +} {10} +test text-9.2.33 {TextWidgetCmd procedure, "count" option} { .t count -chars a 3.0 -} -cleanup { - destroy .t -} -result {9} -test text-10.29 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" - .t tag configure elide -elide 1 - .t tag add elide 2.2 3.4 - .t tag add elide 4.0 4.1 -# Create one visible and one invisible window - frame .t.w1 - frame .t.w2 -# Creating this window here means that the elidden text -# now starts at 2.3 - .t window create 2.1 -window .t.w1 - .t window create 3.1 -window .t.w2 - .t count -displaychars 2.0 4.2 +} {9} +test text-9.2.34 {TextWidgetCmd procedure, "count" option} { .t count -chars 2.0 4.2 -} -cleanup { - destroy .t -} -result {19} -test text-10.30 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert end [string repeat "abcde " 50]\n - .t insert end [string repeat "fghij " 50]\n - .t insert end [string repeat "klmno " 50] +} {19} +destroy .t.w1 +destroy .t.w2 +set current [.t get 1.0 end-1c] +.t delete 1.0 end +.t insert end [string repeat "abcde " 50]\n +.t insert end [string repeat "fghij " 50]\n +.t insert end [string repeat "klmno " 50] +test text-9.2.35 {TextWidgetCmd procedure, "count" option} { .t count -lines 1.0 end -} -cleanup { - destroy .t -} -result {3} -test text-10.31 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert end [string repeat "abcde " 50]\n - .t insert end [string repeat "fghij " 50]\n - .t insert end [string repeat "klmno " 50] +} {3} +test text-9.2.36 {TextWidgetCmd procedure, "count" option} { .t count -lines end 1.0 -} -cleanup { - destroy .t -} -result {-3} -test text-10.32 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert end [string repeat "abcde " 50]\n - .t insert end [string repeat "fghij " 50]\n - .t insert end [string repeat "klmno " 50] - .t count -lines 1.0 2.0 3.0 -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad option "1.0" must be -chars, -displaychars, -displayindices, -displaylines, -indices, -lines, -update, -xpixels, or -ypixels} -test text-10.33 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert end [string repeat "abcde " 50]\n - .t insert end [string repeat "fghij " 50]\n - .t insert end [string repeat "klmno " 50] +} {-3} +test text-9.2.37 {TextWidgetCmd procedure, "count" option} { + list [catch {.t count -lines 1.0 2.0 3.0} res] $res +} {1 {bad option "1.0" must be -chars, -displaychars, -displayindices, -displaylines, -indices, -lines, -update, -xpixels, or -ypixels}} +test text-9.2.38 {TextWidgetCmd procedure, "count" option} { .t count -lines end end -} -cleanup { - destroy .t -} -result {0} -test text-10.34 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert end [string repeat "abcde " 50]\n - .t insert end [string repeat "fghij " 50]\n - .t insert end [string repeat "klmno " 50] +} {0} +test text-9.2.39 {TextWidgetCmd procedure, "count" option} { .t count -lines 1.5 2.5 -} -cleanup { - destroy .t -} -result {1} -test text-10.35 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert end [string repeat "abcde " 50]\n - .t insert end [string repeat "fghij " 50]\n - .t insert end [string repeat "klmno " 50] +} {1} +test text-9.2.40 {TextWidgetCmd procedure, "count" option} { .t count -lines 2.5 "2.5 lineend" -} -cleanup { - destroy .t -} -result {0} -test text-10.36 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert end [string repeat "abcde " 50]\n - .t insert end [string repeat "fghij " 50]\n - .t insert end [string repeat "klmno " 50] +} {0} +test text-9.2.41 {TextWidgetCmd procedure, "count" option} { .t count -lines 2.7 "1.0 lineend" -} -cleanup { - destroy .t -} -result {-1} -test text-10.37 {TextWidgetCmd procedure, "count" option} -setup { - text .t -} -body { - .t insert end [string repeat "abcde " 50]\n - .t insert end [string repeat "fghij " 50]\n - .t insert end [string repeat "klmno " 50] +} {-1} +test text-9.2.42 {TextWidgetCmd procedure, "count" option} { + set old_wrap [.t cget -wrap] .t configure -wrap none - .t count -displaylines 1.0 end -} -cleanup { - destroy .t -} -result {3} -test text-10.38 {TextWidgetCmd procedure, "count" option} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack append . .t {top expand fill} -} -body { - .t configure -width 20 -height 10 - update - .t insert end [string repeat "abcde " 50]\n - .t insert end [string repeat "fghij " 50]\n - .t insert end [string repeat "klmno " 50] + set res [.t count -displaylines 1.0 end] + .t configure -wrap $old_wrap + set res +} {3} +test text-9.2.43 {TextWidgetCmd procedure, "count" option} { .t count -lines -chars -indices -displaylines 1.0 end -} -cleanup { - destroy .t -} -result {3 903 903 45} -test text-10.39 {TextWidgetCmd procedure, "count" option} -setup { - text .t - pack .t +} {3 903 903 45} +.t configure -wrap none +test text-9.2.44 {TextWidgetCmd procedure, "count" option} -setup { + .t delete 1.0 end update set res {} } -body { @@ -2657,12 +698,9 @@ test text-10.39 {TextWidgetCmd procedure, "count" option} -setup { .t tag add hidden 2.9 3.17 .t tag configure hidden -elide true lappend res [.t count -displaylines 1.19 3.24] [.t count -displaylines 1.0 end] -} -cleanup { - destroy .t } -result {2 6 1 5} test text-9.2.45 {TextWidgetCmd procedure, "count" option} -setup { - text .t - pack .t + .t delete 1.0 end update set res {} } -body { @@ -2673,8 +711,6 @@ test text-9.2.45 {TextWidgetCmd procedure, "count" option} -setup { .t tag add hidden 2.15 3.10 .t configure -wrap none set res [.t count -displaylines 2.0 3.0] -} -cleanup { - destroy .t } -result {0} test text-9.2.46 {TextWidgetCmd procedure, "count" option} -setup { toplevel .mytop @@ -2699,8 +735,7 @@ test text-9.2.46 {TextWidgetCmd procedure, "count" option} -setup { destroy .mytop } -result {1 3} test text-9.2.47 {TextWidgetCmd procedure, "count" option} -setup { - text .t - pack .t + .t delete 1.0 end update set res {} } -body { @@ -2713,24 +748,24 @@ test text-9.2.47 {TextWidgetCmd procedure, "count" option} -setup { # next line to be fully sure that asynchronous line heights calculation is # up-to-date otherwise this test may fail (depending on the computer # performance), especially when the . toplevel has small height - .t sync + .t count -update -ypixels 1.0 end set y1 [lindex [.t yview] 1] .t count -displaylines 5.0 11.0 set y2 [lindex [.t yview] 1] .t count -displaylines 5.0 12.0 set y3 [lindex [.t yview] 1] list [expr {$y1 == $y2}] [expr {$y1 == $y3}] -} -cleanup { - destroy .t } -result {1 1} +# Newer tags are higher priority +.t tag configure elide1 -elide 0 +.t tag configure elide2 -elide 1 +.t tag configure elide3 -elide 0 +.t tag configure elide4 -elide 1 -test text-11.1 {counting with tag priority eliding} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack append . .t {top expand fill} -} -body { +test text-0.2.44.0 {counting with tag priority eliding} { + .t delete 1.0 end .t insert end "hello" - .t configure -wrap none list [.t count -displaychars 1.0 1.0] \ [.t count -displaychars 1.0 1.1] \ [.t count -displaychars 1.0 1.2] \ @@ -2739,42 +774,23 @@ test text-11.1 {counting with tag priority eliding} -setup { [.t count -displaychars 1.0 1.5] \ [.t count -displaychars 1.0 1.6] \ [.t count -displaychars 1.0 2.6] \ -} -cleanup { - destroy .t -} -result {0 1 2 3 4 5 5 6} -test text-11.2 {counting with tag priority eliding} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack append . .t {top expand fill} -} -body { +} {0 1 2 3 4 5 5 6} +test text-0.2.44 {counting with tag priority eliding} { + .t delete 1.0 end .t insert end "hello" - .t tag configure elide1 -elide 0 .t tag add elide1 1.2 1.4 .t count -displaychars 1.0 1.5 -} -cleanup { - destroy .t -} -result {5} -test text-11.3 {counting with tag priority eliding} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 -} -body { +} {5} +test text-0.2.45 {counting with tag priority eliding} { + .t delete 1.0 end .t insert end "hello" -# Newer tags are higher priority - .t tag configure elide1 -elide 0 - .t tag configure elide2 -elide 1 - .t tag add elide1 1.2 1.4 .t tag add elide2 1.2 1.4 .t count -displaychars 1.0 1.5 -} -cleanup { - destroy .t -} -result {3} -test text-11.4 {counting with tag priority eliding} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 +} {3} +test text-0.2.46 {counting with tag priority eliding} { set res {} -} -body { + .t delete 1.0 end .t insert end "hello" -# Newer tags are higher priority - .t tag configure elide1 -elide 0 - .t tag configure elide2 -elide 1 - .t tag add elide1 1.2 1.4 .t tag add elide2 1.2 1.4 .t tag add elide1 1.2 1.4 lappend res [.t count -displaychars 1.0 1.5] @@ -2783,19 +799,11 @@ test text-11.4 {counting with tag priority eliding} -setup { .t tag add elide1 1.2 1.4 .t tag add elide2 1.2 1.4 lappend res [.t count -displaychars 1.0 1.5] -} -cleanup { - destroy .t -} -result {3 3} -test text-11.5 {counting with tag priority eliding} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 +} {3 3} +test text-0.2.47 {counting with tag priority eliding} { set res {} -} -body { + .t delete 1.0 end .t insert end "hello" -# Newer tags are higher priority - .t tag configure elide1 -elide 0 - .t tag configure elide2 -elide 1 - .t tag configure elide3 -elide 0 - .t tag add elide1 1.2 1.4 .t tag add elide2 1.2 1.4 .t tag add elide3 1.2 1.4 lappend res [.t count -displaychars 1.0 1.5] @@ -2804,19 +812,11 @@ test text-11.5 {counting with tag priority eliding} -setup { .t tag add elide3 1.2 1.4 .t tag add elide3 1.2 1.4 lappend res [.t count -displaychars 1.0 1.5] -} -cleanup { - destroy .t -} -result {5 5} -test text-11.6 {counting with tag priority eliding} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 +} {5 5} +test text-0.2.48 {counting with tag priority eliding} { set res {} -} -body { + .t delete 1.0 end .t insert end "hello" -# Newer tags are higher priority - .t tag configure elide1 -elide 0 - .t tag configure elide2 -elide 1 - .t tag configure elide3 -elide 0 - .t tag configure elide4 -elide 1 .t tag add elide2 1.2 1.4 .t tag add elide3 1.2 1.4 .t tag add elide4 1.2 1.4 @@ -2829,17 +829,10 @@ test text-11.6 {counting with tag priority eliding} -setup { .t tag add elide2 1.2 1.4 .t tag add elide3 1.2 1.4 lappend res [.t count -displaychars 1.0 1.5] -} -cleanup { - destroy .t -} -result {3 3} -test text-11.7 {counting with tag priority eliding} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 +} {3 3} +test text-0.2.49 {counting with tag priority eliding} { set res {} -} -body { -# Newer tags are higher priority - .t tag configure elide1 -elide 0 - .t tag configure elide2 -elide 1 - .t tag configure elide3 -elide 0 + .t delete 1.0 end .t insert end "hello" .t tag add elide2 1.2 1.4 .t tag add elide3 1.2 1.4 @@ -2851,18 +844,11 @@ test text-11.7 {counting with tag priority eliding} -setup { .t tag add elide2 1.2 1.4 .t tag add elide3 1.2 1.4 lappend res [.t count -displaychars 1.0 1.5] -} -cleanup { - destroy .t -} -result {5 5} -test text-11.8 {counting with tag priority eliding} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack append . .t {top expand fill} +} {5 5} +test text-0.2.50 {counting with tag priority eliding} { set res {} -} -body { + .t delete 1.0 end .t insert end "hello" -# Newer tags are higher priority - .t tag configure elide1 -elide 0 - .t tag configure elide2 -elide 1 .t tag add elide2 1.0 1.5 .t tag add elide1 1.2 1.4 lappend res [.t count -displaychars 1.0 1.5] @@ -2877,14 +863,10 @@ test text-11.8 {counting with tag priority eliding} -setup { lappend res [.t count -displaychars 1.1 1.5] lappend res [.t count -displaychars 1.2 1.5] lappend res [.t count -displaychars 1.3 1.5] -} -cleanup { - destroy .t -} -result {0 0 0 0 3 2 1 1} -test text-11.9 {counting with tag priority eliding} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack append . .t {top expand fill} +} {0 0 0 0 3 2 1 1} +test text-0.2.51 {counting with tag priority eliding} { set res {} -} -body { + .t delete 1.0 end .t tag configure WELCOME -elide 1 .t tag configure SYSTEM -elide 0 .t tag configure TRAFFIC -elide 1 @@ -2905,599 +887,225 @@ test text-11.9 {counting with tag priority eliding} -setup { lappend res [.t index "end -2 indices"] lappend res [.t index "end -2 display indices"] lappend res [.t index "end -2 display chars"] -} -cleanup { - destroy .t -} -result {1 0 0 1 0 2.0 4.0 4.0 4.0 3.0 3.0 3.0 2.0 1.0 1.0} - -test text-11a.1 {TextWidgetCmd procedure, "pendingsync" option} -setup { - destroy .yt -} -body { - text .yt - list [catch {.yt pendingsync mytext} msg] $msg -} -cleanup { - destroy .yt -} -result {1 {wrong # args: should be ".yt pendingsync"}} -test text-11a.2 {TextWidgetCmd procedure, "pendingsync" option} -setup { - destroy .top.yt .top -} -body { - toplevel .top - pack [text .top.yt] - set content {} - for {set i 1} {$i < 300} {incr i} { - append content [string repeat "$i " 15] \n - } - .top.yt insert 1.0 $content - # wait for end of line metrics calculation to get correct $fraction1 - # as a reference - while {[.top.yt pendingsync]} {update} - .top.yt yview moveto 1 - set fraction1 [lindex [.top.yt yview] 0] - set res [expr {$fraction1 > 0}] - .top.yt delete 1.0 end - .top.yt insert 1.0 $content - # ensure the test is relevant - lappend res [.top.yt pendingsync] - # asynchronously wait for completion of line metrics calculation - while {[.top.yt pendingsync]} {update} - .top.yt yview moveto $fraction1 - set fraction2 [lindex [.top.yt yview] 0] - lappend res [expr {$fraction1 == $fraction2}] -} -cleanup { - destroy .top.yt .top -} -result {1 1 1} - -test text-11a.11 {TextWidgetCmd procedure, "sync" option} -setup { - destroy .yt -} -body { - text .yt - list [catch {.yt sync mytext} msg] $msg -} -cleanup { - destroy .yt -} -result {1 {wrong # args: should be ".yt sync ?-command command?"}} -test text-11a.12 {TextWidgetCmd procedure, "sync" option} -setup { - destroy .top.yt .top -} -body { - toplevel .top - pack [text .top.yt] - set content {} - for {set i 1} {$i < 30} {incr i} { - append content [string repeat "$i " 15] \n - } - .top.yt insert 1.0 $content - # wait for end of line metrics calculation to get correct $fraction1 - # as a reference - .top.yt sync - .top.yt yview moveto 1 - set fraction1 [lindex [.top.yt yview] 0] - set res [expr {$fraction1 > 0}] - # first case: do not wait for completion of line metrics calculation - .top.yt delete 1.0 end - .top.yt insert 1.0 $content - .top.yt yview moveto $fraction1 - set fraction2 [lindex [.top.yt yview] 0] - lappend res [expr {$fraction1 == $fraction2}] - # second case: wait for completion of line metrics calculation - .top.yt delete 1.0 end - .top.yt insert 1.0 $content - .top.yt sync - .top.yt yview moveto $fraction1 - set fraction2 [lindex [.top.yt yview] 0] - lappend res [expr {$fraction1 == $fraction2}] -} -cleanup { - destroy .top.yt .top -} -result {1 0 1} - -test text-11a.21 {TextWidgetCmd procedure, "sync" option with -command} -setup { - destroy .yt -} -body { - text .yt - list [catch {.yt sync -comx foo} msg] $msg -} -cleanup { - destroy .yt -} -result {1 {wrong option "-comx": should be "-command"}} -test text-11a.22 {TextWidgetCmd procedure, "sync" option with -command} -setup { - destroy .top.yt .top -} -body { - set res {} - set ::x 0 - toplevel .top - pack [text .top.yt] - set content {} - for {set i 1} {$i < 30} {incr i} { - append content [string repeat "$i " 15] \n - } - .top.yt insert 1.0 $content - # first case: line metrics calculation still running when launching 'sync -command' - lappend res [.top.yt pendingsync] - .top.yt sync -command [list set ::x 1] - lappend res $::x - # now finish line metrics calculations - while {[.top.yt pendingsync]} {update} - lappend res [.top.yt pendingsync] $::x - # second case: line metrics calculation completed when launching 'sync -command' - .top.yt sync -command [list set ::x 2] - lappend res $::x - vwait ::x - lappend res $::x -} -cleanup { - destroy .top.yt .top -} -result {1 0 0 1 1 2} - -test text-11a.31 {"<<WidgetViewSync>>" event} -setup { - destroy .top.yt .top -} -body { - toplevel .top - pack [text .top.yt] - set content {} - for {set i 1} {$i < 300} {incr i} { - append content [string repeat "$i " 15] \n - } - .top.yt insert 1.0 $content - update - bind .top.yt <<WidgetViewSync>> { if {%d} {set yud(%W) 1} } - # wait for end of line metrics calculation to get correct $fraction1 - # as a reference - if {[.top.yt pendingsync]} {vwait yud(.top.yt)} - .top.yt yview moveto 1 - set fraction1 [lindex [.top.yt yview] 0] - set res [expr {$fraction1 > 0}] - .top.yt delete 1.0 end - .top.yt insert 1.0 $content - # synchronously wait for completion of line metrics calculation - # and ensure the test is relevant - set waited 0 - if {[.top.yt pendingsync]} {set waited 1 ; vwait yud(.top.yt)} - lappend res $waited - .top.yt yview moveto $fraction1 - set fraction2 [lindex [.top.yt yview] 0] - lappend res [expr {$fraction1 == $fraction2}] -} -cleanup { - destroy .top.yt .top -} -result {1 1 1} - -test text-11a.41 {"sync" "pendingsync" and <<WidgetViewSync>>} -setup { - destroy .top.yt .top -} -body { - set res {} - toplevel .top - pack [text .top.yt] - set content {} - for {set i 1} {$i < 300} {incr i} { - append content [string repeat "$i " 50] \n - } - bind .top.yt <<WidgetViewSync>> {lappend res Sync:%d} - .top.yt insert 1.0 $content - vwait res ; # event dealt with by the event loop, with %d==0 i.e. we're out of sync - # ensure the test is relevant - lappend res "Pending:[.top.yt pendingsync]" - # - <<WidgetViewSync>> fires when sync returns if there was pending syncs - # - there is no more any pending sync after running 'sync' - .top.yt sync - vwait res ; # event dealt with by the event loop, with %d==1 i.e. we're in sync again - lappend res "Pending:[.top.yt pendingsync]" - set res -} -cleanup { - destroy .top.yt .top -} -result {Sync:0 Pending:1 Sync:1 Pending:0} - -test text-11a.51 {<<WidgetViewSync>> calls TkSendVirtualEvent(), - NOT Tk_HandleEvent(). - Bug [b362182e45704dd7bbd6aed91e48122035ea3d16]} -setup { - destroy .top.t .top -} -body { - set res {} - toplevel .top - pack [text .top.t] - for {set i 1} {$i < 10000} {incr i} { - .top.t insert end "Hello world!\n" - } - bind .top.t <<WidgetViewSync>> {destroy .top.t} - .top.t tag add mytag 1.5 8000.8 ; # shall not crash - update - set res "Still doing fine!" -} -cleanup { - destroy .top.t .top -} -result {Still doing fine!} - -test text-12.1 {TextWidgetCmd procedure, "index" option} -setup { - text .t -} -body { - .t index -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t index index"} -test text-12.2 {TextWidgetCmd procedure, "index" option} -setup { - text .t -} -body { - .t ind a b -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t index index"} -test text-12.3 {TextWidgetCmd procedure, "index" option} -setup { - text .t -} -body { - .t in a b -} -cleanup { - destroy .t -} -returnCodes {error} -result {ambiguous option "in": must be bbox, cget, compare, configure, count, debug, delete, dlineinfo, dump, edit, get, image, index, insert, mark, peer, pendingsync, replace, scan, search, see, sync, tag, window, xview, or yview} -test text-12.4 {TextWidgetCmd procedure, "index" option} -setup { - text .t -} -body { - .t index @xyz -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "@xyz"} -test text-12.5 {TextWidgetCmd procedure, "index" option} -setup { - [text .t] insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" -} -body { +} {1 0 0 1 0 2.0 4.0 4.0 4.0 3.0 3.0 3.0 2.0 1.0 1.0} + +.t delete 1.0 end +.t insert end $current +unset current + +test text-10.1 {TextWidgetCmd procedure, "index" option} { + list [catch {.t index} msg] $msg +} {1 {wrong # args: should be ".t index index"}} +test text-10.2 {TextWidgetCmd procedure, "index" option} { + list [catch {.t ind a b} msg] $msg +} {1 {wrong # args: should be ".t index index"}} +test text-10.3 {TextWidgetCmd procedure, "index" option} { + list [catch {.t in a b} msg] $msg +} {1 {ambiguous option "in": must be bbox, cget, compare, configure, count, debug, delete, dlineinfo, dump, edit, get, image, index, insert, mark, peer, replace, scan, search, see, tag, window, xview, or yview}} +test text-10.4 {TextWidgetCmd procedure, "index" option} { + list [catch {.t index @xyz} msg] $msg +} {1 {bad text index "@xyz"}} +test text-10.5 {TextWidgetCmd procedure, "index" option} { .t index 1.2 -} -cleanup { - destroy .t -} -result 1.2 - +} 1.2 -test text-13.1 {TextWidgetCmd procedure, "insert" option} -setup { - [text .t] insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" -} -body { - .t insert 1.2 -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t insert index chars ?tagList chars tagList ...?"} -test text-13.2 {TextWidgetCmd procedure, "insert" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +test text-11.1 {TextWidgetCmd procedure, "insert" option} { + list [catch {.t insert 1.2} msg] $msg +} {1 {wrong # args: should be ".t insert index chars ?tagList chars tagList ...?"}} +test text-11.2 {TextWidgetCmd procedure, "insert" option} { .t config -state disabled .t insert 1.2 xyzzy .t get 1.0 1.end -} -cleanup { - destroy .t -} -result {Line 1} -test text-13.3 {TextWidgetCmd procedure, "insert" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {Line 1} +.t config -state normal +test text-11.3 {TextWidgetCmd procedure, "insert" option} { .t insert 1.2 xyzzy .t get 1.0 1.end -} -cleanup { - destroy .t -} -result {Lixyzzyne 1} -test text-13.4 {TextWidgetCmd procedure, "insert" option} -setup { - text .t -} -body { - .t insert 1.0 "Line 1 -aefghijklm -12345 -Line 4 -bOy GIrl .#@? x_yz -!@#$% -Line 7" +} {Lixyzzyne 1} +test text-11.4 {TextWidgetCmd procedure, "insert" option} { .t delete 1.0 end .t insert 1.0 "Sample text" x .t tag ranges x -} -cleanup { - destroy .t -} -result {1.0 1.11} -test text-13.5 {TextWidgetCmd procedure, "insert" option} -setup { - text .t -} -body { +} {1.0 1.11} +test text-11.5 {TextWidgetCmd procedure, "insert" option} { + .t delete 1.0 end .t insert 1.0 "Sample text" x .t insert 1.2 "XYZ" y list [.t tag ranges x] [.t tag ranges y] -} -cleanup { - destroy .t -} -result {{1.0 1.2 1.5 1.14} {1.2 1.5}} -test text-13.6 {TextWidgetCmd procedure, "insert" option} -setup { - text .t -} -body { +} {{1.0 1.2 1.5 1.14} {1.2 1.5}} +test text-11.6 {TextWidgetCmd procedure, "insert" option} { + .t delete 1.0 end .t insert 1.0 "Sample text" {x y z} list [.t tag ranges x] [.t tag ranges y] [.t tag ranges z] -} -cleanup { - destroy .t -} -result {{1.0 1.11} {1.0 1.11} {1.0 1.11}} -test text-13.7 {TextWidgetCmd procedure, "insert" option} -setup { - text .t -} -body { +} {{1.0 1.11} {1.0 1.11} {1.0 1.11}} +test text-11.7 {TextWidgetCmd procedure, "insert" option} { + .t delete 1.0 end .t insert 1.0 "Sample text" {x y z} .t insert 1.3 "A" {a b z} list [.t tag ranges a] [.t tag ranges b] [.t tag ranges x] [.t tag ranges y] [.t tag ranges z] -} -cleanup { - destroy .t -} -result {{1.3 1.4} {1.3 1.4} {1.0 1.3 1.4 1.12} {1.0 1.3 1.4 1.12} {1.0 1.12}} -test text-13.8 {TextWidgetCmd procedure, "insert" option} -setup { - text .t -} -body { - .t insert 1.0 "Sample text" "a \{b" -} -cleanup { - destroy .t -} -returnCodes {error} -result {unmatched open brace in list} -test text-13.9 {TextWidgetCmd procedure, "insert" option} -setup { - text .t -} -body { +} {{1.3 1.4} {1.3 1.4} {1.0 1.3 1.4 1.12} {1.0 1.3 1.4 1.12} {1.0 1.12}} +test text-11.8 {TextWidgetCmd procedure, "insert" option} { + .t delete 1.0 end + list [catch {.t insert 1.0 "Sample text" "a \{b"} msg] $msg +} {1 {unmatched open brace in list}} +test text-11.9 {TextWidgetCmd procedure, "insert" option} { + .t delete 1.0 end .t insert 1.0 "First" bold " " {} second "x y z" " third" list [.t get 1.0 1.end] [.t tag ranges bold] [.t tag ranges x] \ [.t tag ranges y] [.t tag ranges z] -} -cleanup { - destroy .t -} -result {{First second third} {1.0 1.5} {1.6 1.12} {1.6 1.12} {1.6 1.12}} -test text-13.10 {TextWidgetCmd procedure, "insert" option} -setup { - text .t -} -body { +} {{First second third} {1.0 1.5} {1.6 1.12} {1.6 1.12} {1.6 1.12}} +test text-11.10 {TextWidgetCmd procedure, "insert" option} { + .t delete 1.0 end .t insert 1.0 "First" bold " second" silly list [.t get 1.0 1.end] [.t tag ranges bold] [.t tag ranges silly] -} -cleanup { - destroy .t -} -result {{First second} {1.0 1.5} {1.5 1.12}} +} {{First second} {1.0 1.5} {1.5 1.12}} # Edit, mark, scan, search, see, tag, window, xview, and yview actions are tested elsewhere. -test text-14.1 {ConfigureText procedure} -setup { - text .t -} -body { - .t configure -state foobar -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad state "foobar": must be disabled or normal} -test text-14.2 {ConfigureText procedure} -setup { - text .t -} -body { - .t configure -spacing1 -2 -spacing2 1 -spacing3 1 - list [.t cget -spacing1] [.t cget -spacing2] [.t cget -spacing3] -} -cleanup { - destroy .t -} -result {0 1 1} -test text-14.3 {ConfigureText procedure} -setup { - text .t -} -body { - .t configure -spacing1 1 -spacing2 -1 -spacing3 1 - list [.t cget -spacing1] [.t cget -spacing2] [.t cget -spacing3] -} -cleanup { - destroy .t -} -result {1 0 1} -test text-14.4 {ConfigureText procedure} -setup { - text .t -} -body { - .t configure -spacing1 1 -spacing2 1 -spacing3 -3 - list [.t cget -spacing1] [.t cget -spacing2] [.t cget -spacing3] -} -cleanup { - destroy .t -} -result {1 1 0} -test text-14.5 {ConfigureText procedure} -setup { - text .t -} -body { - .t configure -tabs {30 foo} -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad tab alignment "foo": must be left, right, center, or numeric} -test text-14.6 {ConfigureText procedure} -setup { - text .t -} -body { - catch {.t configure -tabs {30 foo}} - .t configure -tabs {10 20 30} - return $errorInfo -} -cleanup { - destroy .t -} -result {bad tab alignment "foo": must be left, right, center, or numeric +test text-12.1 {ConfigureText procedure} { + list [catch {.t2 configure -state foobar} msg] $msg +} {1 {bad state "foobar": must be disabled or normal}} +test text-12.2 {ConfigureText procedure} { + .t2 configure -spacing1 -2 -spacing2 1 -spacing3 1 + list [.t2 cget -spacing1] [.t2 cget -spacing2] [.t2 cget -spacing3] +} {0 1 1} +test text-12.3 {ConfigureText procedure} { + .t2 configure -spacing1 1 -spacing2 -1 -spacing3 1 + list [.t2 cget -spacing1] [.t2 cget -spacing2] [.t2 cget -spacing3] +} {1 0 1} +test text-12.4 {ConfigureText procedure} { + .t2 configure -spacing1 1 -spacing2 1 -spacing3 -3 + list [.t2 cget -spacing1] [.t2 cget -spacing2] [.t2 cget -spacing3] +} {1 1 0} +test text-12.5 {ConfigureText procedure} { + set x [list [catch {.t2 configure -tabs {30 foo}} msg] $msg $errorInfo] + .t2 configure -tabs {10 20 30} + set x +} {1 {bad tab alignment "foo": must be left, right, center, or numeric} {bad tab alignment "foo": must be left, right, center, or numeric (while processing -tabs option) invoked from within -".t configure -tabs {30 foo}"} -test text-14.7 {ConfigureText procedure} -setup { - text .t -} -body { - .t configure -tabs {10 20 30} - .t configure -tabs {} - .t cget -tabs -} -cleanup { - destroy .t -} -result {} -test text-14.8 {ConfigureText procedure} -setup { - text .t -} -body { - .t configure -wrap bogus -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad wrap "bogus": must be char, none, or word} -test text-14.9 {ConfigureText procedure} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 -} -body { - .t configure -selectborderwidth 17 -selectforeground #332211 \ +".t2 configure -tabs {30 foo}"}} +test text-12.6 {ConfigureText procedure} { + .t2 configure -tabs {10 20 30} + .t2 configure -tabs {} + .t2 cget -tabs +} {} +test text-12.7 {ConfigureText procedure} { + list [catch {.t2 configure -wrap bogus} msg] $msg +} {1 {bad wrap "bogus": must be char, none, or word}} +test text-12.8 {ConfigureText procedure} { + .t2 configure -selectborderwidth 17 -selectforeground #332211 \ -selectbackground #abc - list [lindex [.t tag config sel -borderwidth] 4] \ - [lindex [.t tag config sel -foreground] 4] \ - [lindex [.t tag config sel -background] 4] -} -cleanup { - destroy .t -} -result {17 #332211 #abc} -test text-14.10 {ConfigureText procedure} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 -} -body { - .t configure -selectborderwidth {} - .t tag cget sel -borderwidth -} -cleanup { - destroy .t -} -result {} -test text-14.11 {ConfigureText procedure} -setup { - text .t -} -body { - .t configure -selectborderwidth foo -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad screen distance "foo"} -test text-14.12 {ConfigureText procedure} -body { - text .t - entry .t.e - .t.e insert end abcdefg - .t.e select from 0 + list [lindex [.t2 tag config sel -borderwidth] 4] \ + [lindex [.t2 tag config sel -foreground] 4] \ + [lindex [.t2 tag config sel -background] 4] +} {17 #332211 #abc} +test text-12.9 {ConfigureText procedure} { + .t2 configure -selectborderwidth {} + .t2 tag cget sel -borderwidth +} {} +test text-12.10 {ConfigureText procedure} { + list [catch {.t2 configure -selectborderwidth foo} msg] $msg +} {1 {bad screen distance "foo"}} +test text-12.11 {ConfigureText procedure} { + catch {destroy .t2} .t.e select to 2 text .t2 -exportselection 1 selection get -} -cleanup { - destroy .t .t2 -} -result {ab} -test text-14.13 {ConfigureText procedure} -body { - text .t - entry .t.e - .t.e insert end abcdefg - .t.e select from 0 +} {ab} +test text-12.12 {ConfigureText procedure} { + catch {destroy .t2} .t.e select to 2 text .t2 -exportselection 0 .t2 insert insert 1234657890 .t2 tag add sel 1.0 1.4 selection get -} -cleanup { - destroy .t .t2 -} -result {ab} -test text-14.14 {ConfigureText procedure} -body { - text .t - entry .t.e - .t.e insert end abcdefg - .t.e select from 0 +} {ab} +test text-12.13 {ConfigureText procedure} { + catch {destroy .t2} .t.e select to 1 text .t2 -exportselection 1 .t2 insert insert 1234657890 .t2 tag add sel 1.0 1.4 selection get -} -cleanup { - destroy .t .t2 -} -result {1234} -test text-14.15 {ConfigureText procedure} -body { - text .t - entry .t.e - .t.e insert end abcdefg - .t.e select from 0 +} {1234} +test text-12.14 {ConfigureText procedure} { + catch {destroy .t2} .t.e select to 1 text .t2 -exportselection 0 .t2 insert insert 1234657890 .t2 tag add sel 1.0 1.4 .t2 configure -exportselection 1 selection get -} -cleanup { - destroy .t2 .t -} -result {1234} -test text-14.16 {ConfigureText procedure} -body { - text .t - entry .t.e - .t.e insert end abcdefg - .t.e select from 0 - text .t2 -exportselection 1 - .t2 insert insert 1234657890 - .t2 tag add sel 1.0 1.4 - selection get - .t2 configure -exportselection 0 - selection get -} -cleanup { - destroy .t .t2 -} -returnCodes error -result {PRIMARY selection doesn't exist or form "STRING" not defined} -test text-14.17 {ConfigureText procedure} -body { - text .t - entry .t.e - .t.e insert end abcdefg - .t.e select from 0 +} {1234} +test text-12.15 {ConfigureText procedure} { + catch {destroy .t2} text .t2 -exportselection 1 .t2 insert insert 1234657890 .t2 tag add sel 1.0 1.4 set result [selection get] .t2 configure -exportselection 0 - catch {selection get} - return $result -} -cleanup { - destroy .t .t2 -} -result {1234} -test text-14.18 {ConfigureText procedure} -constraints fonts -setup { - toplevel .top - text .top.t -font {Courier -12} -borderwidth 2 -highlightthickness 2 -} -body { - .top.t configure -width 20 -height 10 - pack append .top .top.t top - update - set geom [wm geometry .top] - set x [string range $geom 0 [string first + $geom]] -} -cleanup { - destroy .top -} -result {150x140+} -# This test was failing Windows because the title bar on .t was a certain -# minimum size and it was interfering with the size requested by the -setgrid. -# The "overrideredirect" gets rid of the titlebar so the toplevel can shrink -# to the appropriate size. -test text-14.19 {ConfigureText procedure} -setup { - toplevel .top - text .top.t -font {Courier -12} -borderwidth 2 -highlightthickness 2 -} -body { - .top.t configure -width 20 -height 10 -setgrid 1 - wm overrideredirect .top 1 - pack append .top .top.t top - wm geometry .top +0+0 - update - wm geometry .top -} -cleanup { - destroy .top -} -result {20x10+0+0} -# This test was failing on Windows because the title bar on .t was a certain -# minimum size and it was interfering with the size requested by the -setgrid. -# The "overrideredirect" gets rid of the titlebar so the toplevel can shrink -# to the appropriate size. -test text-14.20 {ConfigureText procedure} -setup { - toplevel .top - text .top.t -font {Courier -12} -borderwidth 2 -highlightthickness 2 -} -body { - .top.t configure -width 20 -height 10 -setgrid 1 - wm overrideredirect .top 1 - pack append .top .top.t top - wm geometry .top +0+0 - update - set result [wm geometry .top] - wm geometry .top 15x8 - update - lappend result [wm geometry .top] - .top.t configure -wrap word - update - lappend result [wm geometry .top] -} -cleanup { - destroy .top -} -result {20x10+0+0 15x8+0+0 15x8+0+0} - - -test text-15.1 {TextWorldChanged procedure, spacing options} -constraints { - fonts -} -body { - text .t -width 20 -height 10 -font {Courier -12} -borderwidth 2 -highlightthickness 2 - set result [winfo reqheight .t] - .t configure -spacing1 2 - lappend result [winfo reqheight .t] - .t configure -spacing3 1 - lappend result [winfo reqheight .t] - .t configure -spacing1 0 - lappend result [winfo reqheight .t] -} -cleanup { - destroy .t -} -result {140 160 170 150} - - -test text-16.1 {TextEventProc procedure} -body { + lappend result [catch {selection get} msg] $msg +} {1234 1 {PRIMARY selection doesn't exist or form "STRING" not defined}} +test text-12.16 {ConfigureText procedure} {fonts} { + # This test is non-portable because the window size will vary depending + # on the font size, which can vary. + catch {destroy .t2} + toplevel .t2 + text .t2.t -width 20 -height 10 + pack append .t2 .t2.t top + wm geometry .t2 +0+0 + update + wm geometry .t2 +} {150x140+0+0} +test text-12.17 {ConfigureText procedure} { + # This test was failing Windows because the title bar on .t2 + # was a certain minimum size and it was interfering with the size + # requested by the -setgrid. The "overrideredirect" gets rid of the + # titlebar so the toplevel can shrink to the appropriate size. + catch {destroy .t2} + toplevel .t2 + wm overrideredirect .t2 1 + text .t2.t -width 20 -height 10 -setgrid 1 + pack append .t2 .t2.t top + wm geometry .t2 +0+0 + update + wm geometry .t2 +} {20x10+0+0} +test text-12.18 {ConfigureText procedure} { + # This test was failing on Windows because the title bar on .t2 + # was a certain minimum size and it was interfering with the size + # requested by the -setgrid. The "overrideredirect" gets rid of the + # titlebar so the toplevel can shrink to the appropriate size. + catch {destroy .t2} + toplevel .t2 + wm overrideredirect .t2 1 + text .t2.t -width 20 -height 10 -setgrid 1 + pack append .t2 .t2.t top + wm geometry .t2 +0+0 + update + set result [wm geometry .t2] + wm geometry .t2 15x8 + update + lappend result [wm geometry .t2] + .t2.t configure -wrap word + update + lappend result [wm geometry .t2] +} {20x10+0+0 15x8+0+0 15x8+0+0} + +test text-13.1 {TextWorldChanged procedure, spacing options} fonts { + catch {destroy .t2} + text .t2 -width 20 -height 10 + set result [winfo reqheight .t2] + .t2 configure -spacing1 2 + lappend result [winfo reqheight .t2] + .t2 configure -spacing3 1 + lappend result [winfo reqheight .t2] + .t2 configure -spacing1 0 + lappend result [winfo reqheight .t2] +} {140 160 170 150} + +test text-14.1 {TextEventProc procedure} { text .tx1 -bg #543210 rename .tx1 .tx2 set x {} @@ -3505,363 +1113,265 @@ test text-16.1 {TextEventProc procedure} -body { lappend x [.tx2 cget -bg] destroy .tx1 lappend x [info command .tx*] [winfo exists .tx1] [winfo exists .tx2] -} -cleanup { - destroy .txt1 -} -result {1 #543210 {} 0 0} - +} {1 #543210 {} 0 0} -test text-17.1 {TextCmdDeletedProc procedure} -body { +test text-15.1 {TextCmdDeletedProc procedure} { text .tx1 rename .tx1 {} list [info command .tx*] [winfo exists .tx1] -} -cleanup { - destroy .txt1 -} -result {{} 0} -test text-17.2 {TextCmdDeletedProc procedure, disabling -setgrid} -constraints { - fonts -} -body { - toplevel .top - text .top.t -borderwidth 2 -highlightthickness 2 -font {Courier -12 bold} \ - -setgrid 1 -width 20 -height 10 - pack .top.t - update - set geom [wm geometry .top] - set x [string range $geom 0 [string first + $geom]] - rename .top.t {} - update - set geom [wm geometry .top] - lappend x [string range $geom 0 [string first + $geom]] - return $x -} -cleanup { +} {{} 0} +test text-15.2 {TextCmdDeletedProc procedure, disabling -setgrid} fonts { + catch {destroy .top} + toplevel .top + wm geom .top +0+0 + text .top.t -setgrid 1 -width 20 -height 10 + pack .top.t + update + set x [wm geometry .top] + rename .top.t {} + update + lappend x [wm geometry .top] destroy .top -} -result {20x10+ 150x140+} + set x +} {20x10+0+0 150x140+0+0} - -test text-18.1 {InsertChars procedure} -body { - text .t - .t insert 2.0 abcd\n - .t get 1.0 end -} -cleanup { - destroy .t -} -result {abcd +test text-16.1 {InsertChars procedure} { + catch {destroy .t2} + text .t2 + .t2 insert 2.0 abcd\n + .t2 get 1.0 end +} {abcd } -test text-18.2 {InsertChars procedure} -body { - text .t - .t insert 1.0 abcd\n - .t insert end 123\n - .t get 1.0 end -} -cleanup { - destroy .t -} -result {abcd +test text-16.2 {InsertChars procedure} { + catch {destroy .t2} + text .t2 + .t2 insert 1.0 abcd\n + .t2 insert end 123\n + .t2 get 1.0 end +} {abcd 123 } -test text-18.3 {InsertChars procedure} -body { - text .t - .t insert 1.0 abcd\n - .t insert 10.0 123 - .t get 1.0 end -} -cleanup { - destroy .t -} -result {abcd +test text-16.3 {InsertChars procedure} { + catch {destroy .t2} + text .t2 + .t2 insert 1.0 abcd\n + .t2 insert 10.0 123 + .t2 get 1.0 end +} {abcd 123 } -test text-18.4 {InsertChars procedure, inserting on top visible line} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack .t -} -body { - .t configure -width 20 -height 4 -wrap word - .t insert insert "Now is the time for all great men to come to the " - .t insert insert "aid of their party.\n" - .t insert insert "Now is the time for all great men.\n" - .t see end - update - .t insert 1.0 "Short\n" - .t index @0,0 -} -cleanup { - destroy .t -} -result {2.56} -test text-18.5 {InsertChars procedure, inserting on top visible line} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack .t -} -body { - .t configure -width 20 -height 4 -wrap word - .t insert insert "Now is the time for all great men to come to the " - .t insert insert "aid of their party.\n" - .t insert insert "Now is the time for all great men.\n" - .t see end - update - .t insert 1.55 "Short\n" - .t index @0,0 -} -cleanup { - destroy .t -} -result {2.0} -test text-18.6 {InsertChars procedure, inserting on top visible line} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack .t -} -body { - .t configure -width 20 -height 4 -wrap word - .t insert insert "Now is the time for all great men to come to the " - .t insert insert "aid of their party.\n" - .t insert insert "Now is the time for all great men.\n" - .t see end - update - .t insert 1.56 "Short\n" - .t index @0,0 -} -cleanup { - destroy .t -} -result {1.56} -test text-18.7 {InsertChars procedure, inserting on top visible line} -setup { - text .t -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack .t -} -body { - .t configure -width 20 -height 4 -wrap word - .t insert insert "Now is the time for all great men to come to the " - .t insert insert "aid of their party.\n" - .t insert insert "Now is the time for all great men.\n" - .t see end - update - .t insert 1.57 "Short\n" - .t index @0,0 -} -cleanup { - destroy .t -} -result {1.56} - - -test text-19.1 {DeleteChars procedure} -body { - text .t - .t get 1.0 end -} -cleanup { - destroy .t -} -result { -} -test text-19.2 {DeleteChars procedure} -body { - text .t - .t delete foobar -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "foobar"} -test text-19.3 {DeleteChars procedure} -body { - text .t - .t delete 1.0 lousy -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "lousy"} -test text-19.4 {DeleteChars procedure} -body { - text .t +test text-16.4 {InsertChars procedure, inserting on top visible line} { + catch {destroy .t2} + text .t2 -width 20 -height 4 -wrap word + pack .t2 + .t2 insert insert "Now is the time for all great men to come to the " + .t2 insert insert "aid of their party.\n" + .t2 insert insert "Now is the time for all great men.\n" + .t2 see end + update + .t2 insert 1.0 "Short\n" + .t2 index @0,0 +} {2.56} +test text-16.5 {InsertChars procedure, inserting on top visible line} { + catch {destroy .t2} + text .t2 -width 20 -height 4 -wrap word + pack .t2 + .t2 insert insert "Now is the time for all great men to come to the " + .t2 insert insert "aid of their party.\n" + .t2 insert insert "Now is the time for all great men.\n" + .t2 see end + update + .t2 insert 1.55 "Short\n" + .t2 index @0,0 +} {2.0} +test text-16.6 {InsertChars procedure, inserting on top visible line} { + catch {destroy .t2} + text .t2 -width 20 -height 4 -wrap word + pack .t2 + .t2 insert insert "Now is the time for all great men to come to the " + .t2 insert insert "aid of their party.\n" + .t2 insert insert "Now is the time for all great men.\n" + .t2 see end + update + .t2 insert 1.56 "Short\n" + .t2 index @0,0 +} {1.56} +test text-16.7 {InsertChars procedure, inserting on top visible line} { + catch {destroy .t2} + text .t2 -width 20 -height 4 -wrap word + pack .t2 + .t2 insert insert "Now is the time for all great men to come to the " + .t2 insert insert "aid of their party.\n" + .t2 insert insert "Now is the time for all great men.\n" + .t2 see end + update + .t2 insert 1.57 "Short\n" + .t2 index @0,0 +} {1.56} +catch {destroy .t2} + +proc setup {} { + .t delete 1.0 end .t insert 1.0 "Line 1 abcde 12345 Line 4" +} + +.t delete 1.0 end +test text-17.1 {DeleteChars procedure} { + .t get 1.0 end +} { +} +test text-17.2 {DeleteChars procedure} { + list [catch {.t delete foobar} msg] $msg +} {1 {bad text index "foobar"}} +test text-17.3 {DeleteChars procedure} { + list [catch {.t delete 1.0 lousy} msg] $msg +} {1 {bad text index "lousy"}} +test text-17.4 {DeleteChars procedure} { + setup .t delete 2.1 .t get 1.0 end -} -cleanup { - destroy .t -} -result {Line 1 +} {Line 1 acde 12345 Line 4 } -test text-19.5 {DeleteChars procedure} -body { - text .t - .t insert 1.0 "Line 1 -abcde -12345 -Line 4" +test text-17.5 {DeleteChars procedure} { + setup .t delete 2.3 .t get 1.0 end -} -cleanup { - destroy .t -} -result {Line 1 +} {Line 1 abce 12345 Line 4 } -test text-19.6 {DeleteChars procedure} -body { - text .t - .t insert 1.0 "Line 1 -abcde -12345 -Line 4" +test text-17.6 {DeleteChars procedure} { + setup .t delete 2.end .t get 1.0 end -} -cleanup { - destroy .t -} -result {Line 1 +} {Line 1 abcde12345 Line 4 } -test text-19.7 {DeleteChars procedure} -body { - text .t - .t insert 1.0 "Line 1 -abcde -12345 -Line 4" +test text-17.7 {DeleteChars procedure} { + setup .t tag add sel 4.2 end .t delete 4.2 end list [.t tag ranges sel] [.t get 1.0 end] -} -cleanup { - destroy .t -} -result {{} {Line 1 +} {{} {Line 1 abcde 12345 Li }} -test text-19.8 {DeleteChars procedure} -body { - text .t - .t insert 1.0 "Line 1 -abcde -12345 -Line 4" +test text-17.8 {DeleteChars procedure} { + setup .t tag add sel 1.0 end .t delete 4.0 end list [.t tag ranges sel] [.t get 1.0 end] -} -cleanup { - destroy .t -} -result {{1.0 3.5} {Line 1 +} {{1.0 3.5} {Line 1 abcde 12345 }} -test text-19.9 {DeleteChars procedure} -body { - text .t - .t insert 1.0 "Line 1 -abcde -12345 -Line 4" +test text-17.9 {DeleteChars procedure} { + setup .t delete 2.2 2.2 .t get 1.0 end -} -cleanup { - destroy .t -} -result {Line 1 +} {Line 1 abcde 12345 Line 4 } -test text-19.10 {DeleteChars procedure} -body { - text .t - .t insert 1.0 "Line 1 -abcde -12345 -Line 4" +test text-17.10 {DeleteChars procedure} { + setup .t delete 2.3 2.1 .t get 1.0 end -} -cleanup { - destroy .t -} -result {Line 1 +} {Line 1 abcde 12345 Line 4 } -test text-19.11 {DeleteChars procedure} -body { - toplevel .top - text .top.t -width 20 -height 5 - pack append .top .top.t top - wm geometry .top +0+0 - .top.t insert 1.0 "abc\n123\nx\ny\nz\nq\nr\ns" - update - .top.t delete 1.0 3.0 - list [.top.t index @0,0] [.top.t get @0,0] -} -cleanup { - destroy .top -} -result {1.0 x} -test text-19.12 {DeleteChars procedure} -body { - toplevel .top - text .top.t -width 20 -height 5 - pack append .top .top.t top - wm geometry .top +0+0 - .top.t insert 1.0 "abc\n123\nx\ny\nz\nq\nr\ns" - .top.t yview 3.0 - update - .top.t delete 2.0 4.0 - list [.top.t index @0,0] [.top.t get @0,0] -} -cleanup { - destroy .top -} -result {2.0 y} -test text-19.13 {DeleteChars procedure, updates affecting topIndex} -setup { - toplevel .top - text .top.t -width 1 -height 10 -wrap char - pack .top.t -side left - wm geometry .top +0+0 - update -} -body { - .top.t insert end "abcde\n12345\nqrstuv" - .top.t yview 2.1 - .top.t delete 1.4 2.3 - .top.t index @0,0 -} -cleanup { - destroy .top -} -result {1.2} -test text-19.14 {DeleteChars procedure, updates affecting topIndex} -setup { - toplevel .top - text .top.t -width 1 -height 10 -wrap char - pack .top.t -side left - wm geometry .top +0+0 - update -} -body { - .top.t insert end "abcde\n12345\nqrstuv" - .top.t yview 2.1 - .top.t delete 2.3 2.4 - .top.t index @0,0 -} -cleanup { - destroy .top -} -result {2.0} -test text-19.15 {DeleteChars procedure, updates affecting topIndex} -setup { - toplevel .top - text .top.t -width 1 -height 10 -wrap char - pack .top.t -side left - wm geometry .top +0+0 - update -} -body { - .top.t insert end "abcde\n12345\nqrstuv" - .top.t yview 1.3 - .top.t delete 1.0 1.2 - .top.t index @0,0 -} -cleanup { - destroy .top -} -result {1.1} -test text-19.16 {DeleteChars procedure, updates affecting topIndex} -setup { - toplevel .top - text .top.t -width 6 -height 10 -wrap word - frame .top.f -width 200 -height 20 -relief raised -bd 2 - pack .top.f .top.t -side left - wm geometry .top +0+0 - update -} -body { - .top.t insert end "abc def\n01 2a345 678 9101112\nLine 3\nLine 4\nLine 5\n6\n7\n8\n" - .top.t yview 2.4 - .top.t delete 2.5 - set x [.top.t index @0,0] - .top.t delete 2.5 - list $x [.top.t index @0,0] -} -cleanup { - destroy .top -} -result {2.3 2.0} - - -test text-20.1 {TextFetchSelection procedure} -setup { - text .t -width 20 -height 10 - pack append . .t {top expand fill} - update -} -body { - foreach i {a b c d e f g h i j k l m n o p q r s t u v w x y z} { - .t insert end $i.0$i.1$i.2$i.3$i.4\n - } +test text-17.11 {DeleteChars procedure} { + catch {destroy .t2} + toplevel .t2 + text .t2.t -width 20 -height 5 + pack append .t2 .t2.t top + wm geometry .t2 +0+0 + .t2.t insert 1.0 "abc\n123\nx\ny\nz\nq\nr\ns" + update + .t2.t delete 1.0 3.0 + list [.t2.t index @0,0] [.t2.t get @0,0] +} {1.0 x} +test text-17.12 {DeleteChars procedure} { + catch {destroy .t2} + toplevel .t2 + text .t2.t -width 20 -height 5 + pack append .t2 .t2.t top + wm geometry .t2 +0+0 + .t2.t insert 1.0 "abc\n123\nx\ny\nz\nq\nr\ns" + .t2.t yview 3.0 + update + .t2.t delete 2.0 4.0 + list [.t2.t index @0,0] [.t2.t get @0,0] +} {2.0 y} +catch {destroy .t2} +toplevel .t2 +text .t2.t -width 1 -height 10 -wrap char +frame .t2.f -width 200 -height 20 -relief raised -bd 2 +pack .t2.f .t2.t -side left +wm geometry .t2 +0+0 +update +test text-17.13 {DeleteChars procedure, updates affecting topIndex} { + .t2.t delete 1.0 end + .t2.t insert end "abcde\n12345\nqrstuv" + .t2.t yview 2.1 + .t2.t delete 1.4 2.3 + .t2.t index @0,0 +} {1.2} +test text-17.14 {DeleteChars procedure, updates affecting topIndex} { + .t2.t delete 1.0 end + .t2.t insert end "abcde\n12345\nqrstuv" + .t2.t yview 2.1 + .t2.t delete 2.3 2.4 + .t2.t index @0,0 +} {2.0} +test text-17.15 {DeleteChars procedure, updates affecting topIndex} { + .t2.t delete 1.0 end + .t2.t insert end "abcde\n12345\nqrstuv" + .t2.t yview 1.3 + .t2.t delete 1.0 1.2 + .t2.t index @0,0 +} {1.1} +test text-17.16 {DeleteChars procedure, updates affecting topIndex} { + catch {destroy .t2} + toplevel .t2 + text .t2.t -width 6 -height 10 -wrap word + frame .t2.f -width 200 -height 20 -relief raised -bd 2 + pack .t2.f .t2.t -side left + wm geometry .t2 +0+0 + update + .t2.t insert end "abc def\n01 2345 678 9101112\nLine 3\nLine 4\nLine 5\n6\n7\n8\n" + .t2.t yview 2.4 + .t2.t delete 2.5 + set x [.t2.t index @0,0] + .t2.t delete 2.5 + list $x [.t2.t index @0,0] +} {2.3 2.0} + +.t delete 1.0 end +foreach i {a b c d e f g h i j k l m n o p q r s t u v w x y z} { + .t insert end $i.0$i.1$i.2$i.3$i.4\n +} +test text-18.1 {TextFetchSelection procedure} { .t tag add sel 1.3 3.4 selection get -} -cleanup { - destroy .t -} -result {a.1a.2a.3a.4 +} {a.1a.2a.3a.4 b.0b.1b.2b.3b.4 c.0c} -test text-20.2 {TextFetchSelection procedure} -setup { - text .t -width 20 -height 10 - pack append . .t {top expand fill} - update -} -body { - foreach i {a b c d e f g h i j k l m n o p q r s t u v w x y z} { - .t insert end $i.0$i.1$i.2$i.3$i.4\n - } +test text-18.2 {TextFetchSelection procedure} { .t tag add x 1.2 .t tag add x 1.4 .t tag add x 2.0 @@ -3869,33 +1379,15 @@ test text-20.2 {TextFetchSelection procedure} -setup { .t tag remove sel 1.0 end .t tag add sel 1.0 3.4 selection get -} -cleanup { - destroy .t -} -result {a.0a.1a.2a.3a.4 +} {a.0a.1a.2a.3a.4 b.0b.1b.2b.3b.4 c.0c} -test text-20.3 {TextFetchSelection procedure} -setup { - text .t -width 20 -height 10 - pack append . .t {top expand fill} - update -} -body { - foreach i {a b c d e f g h i j k l m n o p q r s t u v w x y z} { - .t insert end $i.0$i.1$i.2$i.3$i.4\n - } +test text-18.3 {TextFetchSelection procedure} { .t tag remove sel 1.0 end .t tag add sel 13.3 selection get -} -cleanup { - destroy .t -} -result {m} -test text-20.4 {TextFetchSelection procedure} -setup { - text .t -width 20 -height 10 - pack append . .t {top expand fill} - update -} -body { - foreach i {a b c d e f g h i j k l m n o p q r s t u v w x y z} { - .t insert end $i.0$i.1$i.2$i.3$i.4\n - } +} {m} +test text-18.4 {TextFetchSelection procedure} { .t tag remove x 1.0 end .t tag add sel 1.0 3.4 .t tag remove sel 1.0 end @@ -3904,1043 +1396,674 @@ test text-20.4 {TextFetchSelection procedure} -setup { .t tag add sel 10.0 10.end .t tag add sel 13.3 selection get -} -cleanup { - destroy .t -} -result {0a..1b.2b.3b.4 +} {0a..1b.2b.3b.4 cj.0j.1j.2j.3j.4m} -test text-20.5 {TextFetchSelection procedure, long selections} -setup { - text .t -width 20 -height 10 - pack append . .t {top expand fill} - update - set x "" -} -body { - for {set i 1} {$i < 200} {incr i} { - append x "This is line $i, padded to just about 53 characters.\n" - } +set x "" +for {set i 1} {$i < 200} {incr i} { + append x "This is line $i, padded to just about 53 characters.\n" +} +test text-18.5 {TextFetchSelection procedure, long selections} { + .t delete 1.0 end .t insert end $x .t tag add sel 1.0 end - expr {[selection get] eq "$x\n"} -} -cleanup { - destroy .t -} -result {1} - + selection get +} $x\n -test text-21.1 {TkTextLostSelection procedure} -constraints {x11} -setup { - text .t - .t insert 1.0 "Line 1" - entry .t.e - .t.e insert end "abcdefg" +test text-19.1 {TkTextLostSelection procedure} unix { + catch {destroy .t2} text .t2 .t2 insert 1.0 "abc\ndef\nghijk\n1234" -} -body { .t2 tag add sel 1.2 3.3 - .t.e select from 0 .t.e select to 1 .t2 tag ranges sel -} -cleanup { - destroy .t .t2 -} -result {} -test text-21.2 {TkTextLostSelection procedure} -constraints aquaOrWin32 -setup { - text .t - .t insert 1.0 "Line 1" - entry .t.e - .t.e insert end "abcdefg" +} {} +test text-19.2 {TkTextLostSelection procedure} win { + catch {destroy .t2} text .t2 .t2 insert 1.0 "abc\ndef\nghijk\n1234" -} -body { .t2 tag add sel 1.2 3.3 - .t.e select from 0 .t.e select to 1 .t2 tag ranges sel -} -cleanup { - destroy .t .t2 -} -result {1.2 3.3} -test text-21.3 {TkTextLostSelection procedure} -body { - text .t - .t insert 1.0 "abcdef\nghijk\n1234" - .t tag add sel 1.0 1.3 - selection get - selection clear - selection get -} -cleanup { - destroy .t -} -returnCodes error -result {PRIMARY selection doesn't exist or form "STRING" not defined} -test text-21.4 {TkTextLostSelection procedure} -body { - text .t - .t insert 1.0 "abcdef\nghijk\n1234" - .t tag add sel 1.0 1.3 +} {1.2 3.3} +catch {destroy .t2} +test text-19.3 {TkTextLostSelection procedure} { + catch {destroy .t2} + text .t2 + .t2 insert 1.0 "abcdef\nghijk\n1234" + .t2 tag add sel 1.0 1.3 set x [selection get] selection clear - catch {selection get} - .t tag add sel 1.0 1.3 + lappend x [catch {selection get} msg] $msg + .t2 tag add sel 1.0 1.3 lappend x [selection get] -} -cleanup { - destroy .t -} -result {abc abc} - - -test text-22.1 {TextSearchCmd procedure, argument parsing} -body { - text .t - .t search - -} -cleanup { - destroy .t -} -returnCodes error -result {ambiguous switch "-": must be --, -all, -backwards, -count, -elide, -exact, -forwards, -nocase, -nolinestop, -overlap, -regexp, or -strictlimits} -test text-22.2 {TextSearchCmd procedure, -backwards option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {abc 1 {PRIMARY selection doesn't exist or form "STRING" not defined} abc} + +.t delete 1.0 end +.t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +test text-20.1 {TextSearchCmd procedure, argument parsing} { + list [catch {.t search -} msg] $msg +} {1 {bad switch "-": must be --, -all, -backward, -count, -elide, -exact, -forward, -nocase, -nolinestop, -overlap, -regexp, or -strictlimits}} +test text-20.2 {TextSearchCmd procedure, -backwards option} { .t search -backwards xyz 1.4 -} -cleanup { - destroy .t -} -result {1.1} -test text-22.3 {TextSearchCmd procedure, -all option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.1} +test text-20.2.1 {TextSearchCmd procedure, -all option} { .t search -all xyz 1.4 -} -cleanup { - destroy .t -} -result {1.5 3.0 3.5 1.1} -test text-22.4 {TextSearchCmd procedure, -forwards option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.5 3.0 3.5 1.1} +test text-20.3 {TextSearchCmd procedure, -forwards option} { .t search -forwards xyz 1.4 -} -cleanup { - destroy .t -} -result {1.5} -test text-22.5 {TextSearchCmd procedure, -exact option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.5} +test text-20.4 {TextSearchCmd procedure, -exact option} { .t search -f -exact x. 1.0 -} -cleanup { - destroy .t -} -result {1.9} -test text-22.6 {TextSearchCmd procedure, -regexp option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.9} +test text-20.5 {TextSearchCmd procedure, -regexp option} { .t search -b -regexp x.z 1.4 -} -cleanup { - destroy .t -} -result {1.1} -test text-22.7 {TextSearchCmd procedure, -count option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.1} +test text-20.6 {TextSearchCmd procedure, -count option} { set length unmodified list [.t search -count length x. 1.4] $length -} -cleanup { - destroy .t -} -result {1.9 2} -test text-22.8 {TextSearchCmd procedure, -count option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" - .t search -count -} -cleanup { - destroy .t -} -returnCodes {error} -result {no value given for "-count" option} -test text-22.9 {TextSearchCmd procedure, -nocase option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.9 2} +test text-20.7 {TextSearchCmd procedure, -count option} { + list [catch {.t search -count} msg] $msg +} {1 {no value given for "-count" option}} +test text-20.8 {TextSearchCmd procedure, -nocase option} { list [.t search -nocase BaR 1.1] [.t search BaR 1.1] -} -cleanup { - destroy .t -} -result {2.13 2.23} -test text-22.10 {TextSearchCmd procedure, -n ambiguous option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" - .t search -n BaR 1.1 -} -cleanup { - destroy .t -} -returnCodes error -result {ambiguous switch "-n": must be --, -all, -backwards, -count, -elide, -exact, -forwards, -nocase, -nolinestop, -overlap, -regexp, or -strictlimits} -test text-22.11 {TextSearchCmd procedure, -nocase option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {2.13 2.23} +test text-20.9 {TextSearchCmd procedure, -n ambiguous option} { + list [catch {.t search -n BaR 1.1} msg] $msg +} {1 {bad switch "-n": must be --, -all, -backward, -count, -elide, -exact, -forward, -nocase, -nolinestop, -overlap, -regexp, or -strictlimits}} +test text-20.9.1 {TextSearchCmd procedure, -nocase option} { .t search -noc BaR 1.1 -} -cleanup { - destroy .t -} -result {2.13} -test text-22.12 {TextSearchCmd procedure, -nolinestop option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" - .t search -nolinestop BaR 1.1 -} -cleanup { - destroy .t -} -returnCodes {error} -result {the "-nolinestop" option requires the "-regexp" option to be present} -test text-22.13 {TextSearchCmd procedure, -nolinestop option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {2.13} +test text-20.9.2 {TextSearchCmd procedure, -nolinestop option} { + list [catch {.t search -nolinestop BaR 1.1} msg] $msg +} {1 {the "-nolinestop" option requires the "-regexp" option to be present}} +test text-20.9.3 {TextSearchCmd procedure, -nolinestop option} { set msg "" list [.t search -nolinestop -regexp -count msg e.*o 1.1] $msg -} -cleanup { - destroy .t -} -result {1.14 32} -test text-22.14 {TextSearchCmd procedure, -- option} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.14 32} +test text-20.10 {TextSearchCmd procedure, -- option} { .t search -- -forward 1.0 -} -cleanup { - destroy .t -} -result {2.4} -test text-22.15 {TextSearchCmd procedure, argument parsing} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" - .t search abc -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t search ?switches? pattern index ?stopIndex?"} -test text-22.16 {TextSearchCmd procedure, argument parsing} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" - .t search abc d e f -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t search ?switches? pattern index ?stopIndex?"} -test text-22.17 {TextSearchCmd procedure, check index} -body { - text .t - .t search abc gorp -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "gorp"} -test text-22.18 {TextSearchCmd procedure, startIndex == "end"} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {2.4} +test text-20.11 {TextSearchCmd procedure, argument parsing} { + list [catch {.t search abc} msg] $msg +} {1 {wrong # args: should be ".t search ?switches? pattern index ?stopIndex?"}} +test text-20.12 {TextSearchCmd procedure, argument parsing} { + list [catch {.t search abc d e f} msg] $msg +} {1 {wrong # args: should be ".t search ?switches? pattern index ?stopIndex?"}} +test text-20.13 {TextSearchCmd procedure, check index} { + list [catch {.t search abc gorp} msg] $msg +} {1 {bad text index "gorp"}} +test text-20.14 {TextSearchCmd procedure, startIndex == "end"} { .t search non-existent end -} -cleanup { - destroy .t -} -result {} -test text-22.19 {TextSearchCmd procedure, startIndex == "end"} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {} +test text-20.15 {TextSearchCmd procedure, startIndex == "end"} { .t search non-existent end -} -cleanup { - destroy .t -} -result {} -test text-22.20 {TextSearchCmd procedure, bad stopIndex} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" - .t search abc 1.0 lousy -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "lousy"} -test text-22.21 {TextSearchCmd procedure, pattern case conversion} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {} +test text-20.16 {TextSearchCmd procedure, bad stopIndex} { + list [catch {.t search abc 1.0 lousy} msg] $msg +} {1 {bad text index "lousy"}} +test text-20.17 {TextSearchCmd procedure, pattern case conversion} { list [.t search -nocase BAR 1.1] [.t search BAR 1.1] -} -cleanup { - destroy .t -} -result {2.13 {}} -test text-22.22 {TextSearchCmd procedure, bad regular expression pattern} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" - .t search -regexp a( 1.0 -} -cleanup { - destroy .t -} -returnCodes {error} -result {couldn't compile regular expression pattern: parentheses () not balanced} -test text-22.23 {TextSearchCmd procedure, skip dummy last line} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {2.13 {}} +test text-20.18 {TextSearchCmd procedure, bad regular expression pattern} { + list [catch {.t search -regexp a( 1.0} msg] $msg +} {1 {couldn't compile regular expression pattern: parentheses () not balanced}} +test text-20.19 {TextSearchCmd procedure, skip dummy last line} { .t search -backwards BaR end 1.0 -} -cleanup { - destroy .t -} -result {2.23} -test text-22.24 {TextSearchCmd procedure, skip dummy last line} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {2.23} +test text-20.20 {TextSearchCmd procedure, skip dummy last line} { .t search -backwards \n end 1.0 -} -cleanup { - destroy .t -} -result {3.9} -test text-22.25 {TextSearchCmd procedure, skip dummy last line} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {3.9} +test text-20.21 {TextSearchCmd procedure, skip dummy last line} { .t search \n end -} -cleanup { - destroy .t -} -result {1.15} -test text-22.26 {TextSearchCmd procedure, skip dummy last line} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.15} +test text-20.22 {TextSearchCmd procedure, skip dummy last line} { .t search -back \n 1.0 -} -cleanup { - destroy .t -} -result {3.9} -test text-22.27 {TextSearchCmd procedure, extract line contents} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {3.9} +test text-20.23 {TextSearchCmd procedure, extract line contents} { .t tag add foo 1.2 .t tag add x 1.3 .t mark set silly 1.2 .t search xyz 3.6 -} -cleanup { - destroy .t -} -result {1.1} -test text-22.28 {TextSearchCmd procedure, stripping newlines} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.1} +test text-20.24 {TextSearchCmd procedure, stripping newlines} { .t search the\n 1.0 -} -cleanup { - destroy .t -} -result {1.12} -test text-22.29 {TextSearchCmd procedure, handling newlines} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.12} +test text-20.25 {TextSearchCmd procedure, handling newlines} { .t search -regexp the\n 1.0 -} -cleanup { - destroy .t -} -result {1.12} -test text-22.30 {TextSearchCmd procedure, stripping newlines} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.12} +test text-20.26 {TextSearchCmd procedure, stripping newlines} { .t search -regexp {the$} 1.0 -} -cleanup { - destroy .t -} -result {1.12} -test text-22.31 {TextSearchCmd procedure, handling newlines} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.12} +test text-20.27 {TextSearchCmd procedure, handling newlines} { .t search -regexp \n 1.0 -} -cleanup { - destroy .t -} -result {1.15} -test text-22.32 {TextSearchCmd procedure, line case conversion} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.15} +test text-20.28 {TextSearchCmd procedure, line case conversion} { list [.t search -nocase bar 2.18] [.t search bar 2.18] -} -cleanup { - destroy .t -} -result {2.23 2.13} -test text-22.33 {TextSearchCmd procedure, firstChar and lastChar} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {2.23 2.13} +test text-20.29 {TextSearchCmd procedure, firstChar and lastChar} { .t search -backwards xyz 1.6 -} -cleanup { - destroy .t -} -result {1.5} -test text-22.34 {TextSearchCmd procedure, firstChar and lastChar} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.5} +test text-20.30 {TextSearchCmd procedure, firstChar and lastChar} { .t search -backwards xyz 1.5 -} -cleanup { - destroy .t -} -result {1.1} -test text-22.35 {TextSearchCmd procedure, firstChar and lastChar} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.1} +test text-20.31 {TextSearchCmd procedure, firstChar and lastChar} { .t search xyz 1.5 -} -cleanup { - destroy .t -} -result {1.5} -test text-22.36 {TextSearchCmd procedure, firstChar and lastChar} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.5} +test text-20.32 {TextSearchCmd procedure, firstChar and lastChar} { .t search xyz 1.6 -} -cleanup { - destroy .t -} -result {3.0} -test text-22.37 {TextSearchCmd procedure, firstChar and lastChar} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {3.0} +test text-20.33 {TextSearchCmd procedure, firstChar and lastChar} { .t search {} 1.end -} -cleanup { - destroy .t -} -result {1.15} -test text-22.38 {TextSearchCmd procedure, firstChar and lastChar} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.15} +test text-20.34 {TextSearchCmd procedure, firstChar and lastChar} { .t search f 1.end -} -cleanup { - destroy .t -} -result {2.0} -test text-22.39 {TextSearchCmd procedure, firstChar and lastChar} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {2.0} +test text-20.35 {TextSearchCmd procedure, firstChar and lastChar} { .t search {} end -} -cleanup { - destroy .t -} -result {1.0} -test text-22.40 {TextSearchCmd procedure, regexp finds empty lines} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" -# Test for fix of bug #1643 +} {1.0} +test text-20.35a {TextSearchCmd procedure, regexp finds empty lines} { + # Test for fix of bug #1643 .t insert end "\n" tk::TextSetCursor .t 4.0 .t search -forward -regexp {^$} insert end -} -cleanup { - destroy .t -} -result {4.0} -test text-22.41 {TextSearchCmd procedure, firstChar and lastChar} -setup { - toplevel .top - text .top.t -width 30 -height 10 -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack .top.t -} -body { - .top.t insert 1.0 "This is a line\nand this is another" - .top.t insert end "\nand this is yet another" - frame .top.f -width 20 -height 20 -bd 2 -relief raised - .top.t window create 2.5 -window .top.f - .top.t search his 2.6 -} -cleanup { - destroy .top -} -result {2.6} -test text-22.42 {TextSearchCmd procedure, firstChar and lastChar} -setup { - toplevel .top - text .top.t -width 30 -height 10 -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack .top.t -} -body { - .top.t insert 1.0 "This is a line\nand this is another" - .top.t insert end "\nand this is yet another" - frame .top.f -width 20 -height 20 -bd 2 -relief raised - .top.t window create 2.5 -window .top.f - .top.t search this 2.6 -} -cleanup { - destroy .top -} -result {3.4} -test text-22.43 {TextSearchCmd procedure, firstChar and lastChar} -setup { - toplevel .top - text .top.t -width 30 -height 10 -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack .top.t -} -body { - .top.t insert 1.0 "This is a line\nand this is another" - .top.t insert end "\nand this is yet another" - frame .top.f -width 20 -height 20 -bd 2 -relief raised - .top.t window create 2.5 -window .top.f - .top.t search is 2.6 -} -cleanup { - destroy .top -} -result {2.7} -test text-22.44 {TextSearchCmd procedure, firstChar and lastChar} -setup { - toplevel .top - text .top.t -width 30 -height 10 -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack .top.t -} -body { - .top.t insert 1.0 "This is a line\nand this is another" - .top.t insert end "\nand this is yet another" - frame .top.f -width 20 -height 20 -bd 2 -relief raised - .top.t window create 2.5 -window .top.f - .top.t search his 2.7 -} -cleanup { - destroy .top -} -result {3.5} -test text-22.45 {TextSearchCmd procedure, firstChar and lastChar} -setup { - toplevel .top - text .top.t -width 30 -height 10 -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack .top.t -} -body { - .top.t insert 1.0 "This is a line\nand this is another" - .top.t insert end "\nand this is yet another" - frame .top.f -width 20 -height 20 -bd 2 -relief raised - .top.t window create 2.5 -window .top.f - .top.t search -backwards "his is another" 2.6 -} -cleanup { - destroy .top -} -result {2.6} -test text-22.46 {TextSearchCmd procedure, firstChar and lastChar} -setup { - toplevel .top - text .top.t -width 30 -height 10 -font {Courier -12} -borderwidth 2 -highlightthickness 2 - pack .top.t -} -body { - .top.t insert 1.0 "This is a line\nand this is another" - .top.t insert end "\nand this is yet another" - frame .top.f -width 20 -height 20 -bd 2 -relief raised - .top.t window create 2.5 -window .top.f - .top.t search -backwards "his is" 2.6 -} -cleanup { - destroy .top -} -result {1.1} -test text-22.47 {TextSearchCmd procedure, firstChar and lastChar} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {4.0} + +catch {destroy .t2} +toplevel .t2 +wm geometry .t2 +0+0 +text .t2.t -width 30 -height 10 +pack .t2.t +.t2.t insert 1.0 "This is a line\nand this is another" +.t2.t insert end "\nand this is yet another" +frame .t2.f -width 20 -height 20 -bd 2 -relief raised +.t2.t window create 2.5 -window .t2.f +test text-20.36 {TextSearchCmd procedure, firstChar and lastChar} { + .t2.t search his 2.6 +} {2.6} +test text-20.37 {TextSearchCmd procedure, firstChar and lastChar} { + .t2.t search this 2.6 +} {3.4} +test text-20.38 {TextSearchCmd procedure, firstChar and lastChar} { + .t2.t search is 2.6 +} {2.7} +test text-20.39 {TextSearchCmd procedure, firstChar and lastChar} { + .t2.t search his 2.7 +} {3.5} +test text-20.40 {TextSearchCmd procedure, firstChar and lastChar} { + .t2.t search -backwards "his is another" 2.6 +} {2.6} +test text-20.41 {TextSearchCmd procedure, firstChar and lastChar} { + .t2.t search -backwards "his is" 2.6 +} {1.1} +destroy .t2 +test text-20.42 {TextSearchCmd procedure, firstChar and lastChar} { .t search -backwards forw 2.5 -} -cleanup { - destroy .t -} -result {2.5} -test text-22.48 {TextSearchCmd procedure, firstChar and lastChar} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {2.5} +test text-20.43 {TextSearchCmd procedure, firstChar and lastChar} { .t search forw 2.5 -} -cleanup { - destroy .t -} -result {2.5} -test text-22.49 {TextSearchCmd procedure, firstChar and lastChar} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" - catch {destroy .t} +} {2.5} +test text-20.44 {TextSearchCmd procedure, firstChar and lastChar} { + catch {destroy .t2} text .t2 list [.t2 search a 1.0] [.t2 search -backward a 1.0] -} -cleanup { - destroy .t .t2 -} -result {{} {}} -test text-22.50 {TextSearchCmd procedure, regexp match length} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {{} {}} +test text-20.45 {TextSearchCmd procedure, regexp match length} { set length unchanged list [.t search -regexp -count length x(.)(.*)z 1.1] $length -} -cleanup { - destroy .t -} -result {1.1 7} -test text-22.51 {TextSearchCmd procedure, regexp match length} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.1 7} +test text-20.46 {TextSearchCmd procedure, regexp match length} { set length unchanged list [.t search -regexp -backward -count length fo* 2.5] $length -} -cleanup { - destroy .t -} -result {2.0 3} -test text-22.52 {TextSearchCmd procedure, checking stopIndex} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {2.0 3} +test text-20.47 {TextSearchCmd procedure, checking stopIndex} { list [.t search bar 2.1 2.13] [.t search bar 2.1 2.14] \ [.t search bar 2.12 2.14] [.t search bar 2.14 2.14] -} -cleanup { - destroy .t -} -result {{} 2.13 2.13 {}} -test text-22.53 {TextSearchCmd procedure, checking stopIndex} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {{} 2.13 2.13 {}} +test text-20.48 {TextSearchCmd procedure, checking stopIndex} { list [.t search -backwards bar 2.20 2.13] \ [.t search -backwards bar 2.20 2.14] \ [.t search -backwards bar 2.14 2.13] \ [.t search -backwards bar 2.13 2.13] -} -cleanup { - destroy .t -} -result {2.13 {} 2.13 {}} -test text-22.54 {TextSearchCmd procedure, checking stopIndex} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {2.13 {} 2.13 {}} +test text-20.48.1 {TextSearchCmd procedure, checking stopIndex} { list [.t search -backwards -strict bar 2.20 2.13] \ [.t search -backwards -strict bar 2.20 2.14] \ [.t search -backwards -strict bar 2.14 2.13] \ [.t search -backwards -strict bar 2.13 2.13] -} -cleanup { - destroy .t -} -result {2.13 {} {} {}} -test text-22.55 {TextSearchCmd procedure, embedded windows and index/count} -setup { - text .t +} {2.13 {} {} {}} +test text-20.49 {TextSearchCmd procedure, embedded windows and index/count} { frame .t.f1 -width 20 -height 20 -relief raised -bd 2 frame .t.f2 -width 20 -height 20 -relief raised -bd 2 frame .t.f3 -width 20 -height 20 -relief raised -bd 2 frame .t.f4 -width 20 -height 20 -relief raised -bd 2 - set result "" -} -body { - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" .t window create 2.10 -window .t.f3 .t window create 2.8 -window .t.f2 .t window create 2.8 -window .t.f1 .t window create 2.1 -window .t.f4 + set result "" lappend result [.t search -count x forward 1.0] $x lappend result [.t search -count x wa 1.0] $x - return $result -} -cleanup { - destroy .t -} -result {2.6 10 2.11 2} -test text-22.56 {TextSearchCmd procedure, error setting variable} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" + .t delete 2.1 + .t delete 2.8 2.10 + .t delete 2.10 + set result +} {2.6 10 2.11 2} +test text-20.50 {TextSearchCmd procedure, error setting variable} { + catch {unset a} set a 44 - .t search -count a(2) xyz 1.0 -} -cleanup { - destroy .t -} -returnCodes {error} -result {can't set "a(2)": variable isn't array} -test text-22.57 {TextSearchCmd procedure, wrap-around} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" + list [catch {.t search -count a(2) xyz 1.0} msg] $msg +} {1 {can't set "a(2)": variable isn't array}} +test text-20.51 {TextSearchCmd procedure, wrap-around} { .t search -backwards xyz 1.1 -} -cleanup { - destroy .t -} -result {3.5} -test text-22.58 {TextSearchCmd procedure, wrap-around} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {3.5} +test text-20.52 {TextSearchCmd procedure, wrap-around} { .t search -backwards xyz 1.1 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.59 {TextSearchCmd procedure, wrap-around} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {} +test text-20.53 {TextSearchCmd procedure, wrap-around} { .t search xyz 3.6 -} -cleanup { - destroy .t -} -result {1.1} -test text-22.60 {TextSearchCmd procedure, wrap-around} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.1} +test text-20.54 {TextSearchCmd procedure, wrap-around} { .t search xyz 3.6 end -} -cleanup { - destroy .t -} -result {} -test text-22.61 {TextSearchCmd procedure, no match} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {} +test text-20.55 {TextSearchCmd procedure, no match} { .t search non_existent 3.5 -} -cleanup { - destroy .t -} -result {} -test text-22.62 {TextSearchCmd procedure, no match} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {} +test text-20.56 {TextSearchCmd procedure, no match} { .t search -regexp non_existent 3.5 -} -cleanup { - destroy .t -} -result {} -test text-22.63 {TextSearchCmd procedure, special cases} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {} +test text-20.57 {TextSearchCmd procedure, special cases} { .t search -back x 1.1 -} -cleanup { - destroy .t -} -result {1.0} -test text-22.64 {TextSearchCmd procedure, special cases} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.0} +test text-20.58 {TextSearchCmd procedure, special cases} { .t search -back x 1.0 -} -cleanup { - destroy .t -} -result {3.8} -test text-22.65 {TextSearchCmd procedure, special cases} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {3.8} +test text-20.59 {TextSearchCmd procedure, special cases} { .t search \n {end-2c} -} -cleanup { - destroy .t -} -result {3.9} -test text-22.66 {TextSearchCmd procedure, special cases} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {3.9} +test text-20.60 {TextSearchCmd procedure, special cases} { .t search \n end -} -cleanup { - destroy .t -} -result {1.15} -test text-22.67 {TextSearchCmd procedure, special cases} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" +} {1.15} +test text-20.61 {TextSearchCmd procedure, special cases} { .t search x 1.0 -} -cleanup { - destroy .t -} -result {1.0} -test text-22.68 {TextSearchCmd, freeing copy of pattern} -body { - text .t - .t insert end "xxyz xyz x. the\nfoo -forward bar xxxxx BaR foo\nxyz xxyzx" -# This test doesn't return a result, but it will generate -# a core leak if the pattern copy isn't properly freed. -# (actually in Tk 8.5 objectification means there is no -# longer a copy of the pattern, but we leave this test in -# anyway). +} {1.0} +test text-20.62 {TextSearchCmd, freeing copy of pattern} { + # This test doesn't return a result, but it will generate + # a core leak if the pattern copy isn't properly freed. + # (actually in Tk 8.5 objectification means there is no + # longer a copy of the pattern, but we leave this test in + # anyway). set p abcdefg1234567890 set p $p$p$p$p$p$p$p$p set p $p$p$p$p$p .t search -nocase $p 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.69 {TextSearchCmd, unicode} -body { - text .t +} {} +test text-20.63 {TextSearchCmd, unicode} { + .t delete 1.0 end .t insert end "foo\u30c9\u30cabar" .t search \u30c9\u30ca 1.0 -} -cleanup { - destroy .t -} -result {1.3} -test text-22.70 {TextSearchCmd, unicode} -body { - text .t +} 1.3 +test text-20.64 {TextSearchCmd, unicode} { + .t delete 1.0 end .t insert end "foo\u30c9\u30cabar" list [.t search -count n \u30c9\u30ca 1.0] $n -} -cleanup { - destroy .t -} -result {1.3 2} -test text-22.71 {TextSearchCmd, unicode with non-text segments} -body { - text .t +} {1.3 2} +test text-20.65 {TextSearchCmd, unicode with non-text segments} { + .t delete 1.0 end button .b1 -text baz .t insert end "foo\u30c9" .t window create end -window .b1 .t insert end "\u30cabar" - list [.t search -count n \u30c9\u30ca 1.0] $n -} -cleanup { - destroy .t .b1 -} -result {1.3 3} -test text-22.72 {TextSearchCmd, hidden text does not affect match index} -body { - pack [text .t] - .t insert end "12345H7890" - .t search 7 1.0 -} -cleanup { - destroy .t -} -result {1.6} -test text-22.73 {TextSearchCmd, hidden text does not affect match index} -body { - pack [text .t] - .t insert end "12345H7890" - .t tag configure hidden -elide true - .t tag add hidden 1.5 - .t search 7 1.0 -} -cleanup { - destroy .t -} -result {1.6} -test text-22.74 {TextSearchCmd, hidden text does not affect match index} -body { - pack [text .t] - .t insert end "foobar\nbarbaz\nbazboo" - .t search boo 1.0 -} -cleanup { - destroy .t -} -result {3.3} -test text-22.75 {TextSearchCmd, hidden text does not affect match index} -body { - pack [text .t] - .t insert end "foobar\nbarbaz\nbazboo" - .t tag configure hidden -elide true - .t tag add hidden 2.0 3.0 - .t search boo 1.0 -} -cleanup { - destroy .t -} -result {3.3} -test text-22.76 {TextSearchCmd, -regexp -nocase searches} -body { + set result [list [.t search -count n \u30c9\u30ca 1.0] $n] + destroy .b1 + set result +} {1.3 3} +test text-20.66 {TextSearchCmd, hidden text does not affect match index} { + deleteWindows + pack [text .t2] + .t2 insert end "12345H7890" + .t2 search 7 1.0 +} 1.6 +test text-20.67 {TextSearchCmd, hidden text does not affect match index} { + deleteWindows + pack [text .t2] + .t2 insert end "12345H7890" + .t2 tag configure hidden -elide true + .t2 tag add hidden 1.5 + .t2 search 7 1.0 +} 1.6 +test text-20.68 {TextSearchCmd, hidden text does not affect match index} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nbarbaz\nbazboo" + .t2 search boo 1.0 +} 3.3 +test text-20.69 {TextSearchCmd, hidden text does not affect match index} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nbarbaz\nbazboo" + .t2 tag configure hidden -elide true + .t2 tag add hidden 2.0 3.0 + .t2 search boo 1.0 +} 3.3 +test text-20.70 {TextSearchCmd, -regexp -nocase searches} { + catch {destroy .t} pack [text .t] .t insert end "word1 word2" - .t search -nocase -regexp {\mword.} 1.0 end -} -cleanup { + set res [.t search -nocase -regexp {\mword.} 1.0 end] destroy .t -} -result {1.0} -test text-22.77 {TextSearchCmd, -regexp -nocase searches} -body { + set res +} 1.0 +test text-20.71 {TextSearchCmd, -regexp -nocase searches} { + catch {destroy .t} pack [text .t] .t insert end "word1 word2" - .t search -nocase -regexp {word.\M} 1.0 end -} -cleanup { + set res [.t search -nocase -regexp {word.\M} 1.0 end] destroy .t -} -result {1.0} -test text-22.78 {TextSearchCmd, -regexp -nocase searches} -body { + set res +} 1.0 +test text-20.72 {TextSearchCmd, -regexp -nocase searches} { + catch {destroy .t} pack [text .t] .t insert end "word1 word2" - .t search -nocase -regexp {word.\W} 1.0 end -} -cleanup { - destroy .t -} -result {1.0} -test text-22.79 {TextSearchCmd, hidden text and start index} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t search bar 1.3 -} -cleanup { - destroy .t -} -result {1.3} -test text-22.80 {TextSearchCmd, hidden text shouldn't influence start index} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t tag configure hidden -elide true - .t tag add hidden 1.0 1.2 - .t search bar 1.3 -} -cleanup { - destroy .t -} -result {1.3} -test text-22.81 {TextSearchCmd, hidden text inside match must count in length} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t tag configure hidden -elide true - .t tag add hidden 1.2 1.4 - list [.t search -count foo foar 1.3] $foo -} -cleanup { + set res [.t search -nocase -regexp {word.\W} 1.0 end] destroy .t -} -result {1.0 6} -test text-22.82 {TextSearchCmd, hidden text inside match must count in length} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t tag configure hidden -elide true - .t tag add hidden 1.2 1.4 + set res +} 1.0 +test text-20.73 {TextSearchCmd, hidden text and start index} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 search bar 1.3 +} 1.3 +test text-20.74 {TextSearchCmd, hidden text shouldn't influence start index} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 tag configure hidden -elide true + .t2 tag add hidden 1.0 1.2 + .t2 search bar 1.3 +} 1.3 +test text-20.75 {TextSearchCmd, hidden text inside match must count in length} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 tag configure hidden -elide true + .t2 tag add hidden 1.2 1.4 + list [.t2 search -count foo foar 1.3] $foo +} {1.0 6} +test text-20.75.1 {TextSearchCmd, hidden text inside match must count in length} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 tag configure hidden -elide true + .t2 tag add hidden 1.2 1.4 list \ - [.t search -strict -count foo foar 1.3] \ - [.t search -strict -count foo foar 2.3] $foo -} -cleanup { - destroy .t -} -result {{} 1.0 6} -test text-22.83 {TextSearchCmd, hidden text and start index} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t search -regexp bar 1.3 -} -cleanup { - destroy .t -} -result {1.3} -test text-22.84 {TextSearchCmd, hidden text shouldn't influence start index} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t tag configure hidden -elide true - .t tag add hidden 1.0 1.2 - .t search -regexp bar 1.3 -} -cleanup { - destroy .t -} -result {1.3} -test text-22.85 {TextSearchCmd, hidden text inside match must count in length} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t tag configure hidden -elide true - .t tag add hidden 1.2 1.4 - list [.t search -regexp -count foo foar 1.3] $foo -} -cleanup { - destroy .t -} -result {1.0 6} -test text-22.86 {TextSearchCmd, hidden text inside match must count in length} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t tag configure hidden -elide true - .t tag add hidden 1.2 1.4 - list [.t search -count foo foar 1.3] $foo -} -cleanup { - destroy .t -} -result {1.0 6} -test text-22.87 {TextSearchCmd, hidden text inside match must count in length} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t tag configure hidden -elide true - .t tag add hidden 1.2 1.4 - .t search -strict -count foo foar 1.3 -} -cleanup { - destroy .t -} -result {} -test text-22.88 {TextSearchCmd, hidden text inside match must count in length} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoar" - .t tag configure hidden -elide true - .t tag add hidden 1.2 1.4 - .t tag add hidden 2.2 2.4 - list [.t search -regexp -all -count foo foar 1.3] $foo -} -cleanup { - destroy .t -} -result {{2.0 3.0 1.0} {6 4 6}} -test text-22.89 {TextSearchCmd, hidden text inside match must count in length} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoar" - .t tag configure hidden -elide true - .t tag add hidden 1.2 1.4 - .t tag add hidden 2.2 2.4 - list [.t search -all -count foo foar 1.3] $foo -} -cleanup { - destroy .t -} -result {{2.0 3.0 1.0} {6 4 6}} -test text-22.90 {TextSearchCmd, hidden text inside match must count in length} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoar" - .t tag configure hidden -elide true - .t tag add hidden 1.2 1.4 - .t tag add hidden 2.2 2.4 - list [.t search -strict -all -count foo foar 1.3] $foo -} -cleanup { - destroy .t -} -result {{2.0 3.0} {6 4}} -test text-22.91 {TextSearchCmd, single line with -all} -body { - pack [text .t] - .t insert end " X\n X\n X\n X\n X\n X\n" - .t search -all -regexp { +| *\n} 1.0 end -} -cleanup { - destroy .t -} -result {1.0 1.2 2.0 2.2 3.0 3.2 4.0 4.2 5.0 5.2 6.0 6.2 7.0} -test text-22.92 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -count foo foobar\nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {1.0 10} -test text-22.93 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -count foo bar\nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {1.3 7} -test text-22.94 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -count foo \nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {1.6 4} -test text-22.95 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -count foo bar\nfoobar\nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {1.3 14} -test text-22.96 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t search -count foo bar\nfoobar\nfoobanearly 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.97 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -regexp -count foo foobar\nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {1.0 10} -test text-22.98 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -regexp -count foo bar\nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {1.3 7} -test text-22.99 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -regexp -count foo \nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {1.6 4} -test text-22.100 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -regexp -count foo bar\nfoobar\nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {1.3 14} -test text-22.101 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t search -regexp -count foo bar\nfoobar\nfoobanearly 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.102 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfaoobar\nfoobar" - .t search -regexp -count foo bar\nfoo 1.0 -} -cleanup { - destroy .t -} -result {2.4} -test text-22.103 {TextSearchCmd, multiline matching end of window} -body { - pack [text .t] - .t insert end "foobar\nfaoobar\nfoobar" - .t search -regexp -count foo bar\nfoobar\n\n 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.104 {TextSearchCmd, multiline matching end of window} -body { - pack [text .t] - .t search "\n\n" 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.105 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -backwards -count foo foobar\nfoo end] $foo -} -cleanup { - destroy .t -} -result {2.0 10} -test text-22.106 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -backwards -count foo bar\nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {2.3 7} -test text-22.107 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -backwards -count foo \nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {2.6 4} -test text-22.108 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -backwards -count foo bar\nfoobar\nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {1.3 14} -test text-22.109 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t search -backwards -count foo bar\nfoobar\nfoobanearly 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.110 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -backwards -regexp -count foo foobar\nfoo end] $foo -} -cleanup { - destroy .t -} -result {2.0 10} -test text-22.111 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -backwards -regexp -count foo foobar\nfo end] $foo -} -cleanup { - destroy .t -} -result {2.0 9} -test text-22.112 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -backwards -regexp -count foo bar\nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {2.3 7} -test text-22.113 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -backwards -regexp -count foo \nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {2.6 4} -test text-22.114 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - list [.t search -backwards -regexp -count foo bar\nfoobar\nfoo 1.0] $foo -} -cleanup { - destroy .t -} -result {1.3 14} -test text-22.115 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t search -backwards -regexp -count foo bar\nfoobar\nfoobanearly 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.116 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfaoobar\nfoobar" - .t search -backwards -regexp -count foo bar\nfoo 1.0 -} -cleanup { - destroy .t -} -result {2.4} -test text-22.117 {TextSearchCmd, multiline matching end of window} -body { - pack [text .t] - .t insert end "foobar\nfaoobar\nfoobar" - .t search -backwards -regexp -count foo bar\nfoobar\n\n 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.118 {TextSearchCmd, multiline matching end of window} -body { - pack [text .t] - .t search -backwards "\n\n" 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.119 {TextSearchCmd, multiline regexp matching} -body { - pack [text .t] - .t insert 1.0 { Tcl_Obj *objPtr)); + [.t2 search -strict -count foo foar 1.3] \ + [.t2 search -strict -count foo foar 2.3] $foo +} {{} 1.0 6} +test text-20.76 {TextSearchCmd, hidden text and start index} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 search -regexp bar 1.3 +} 1.3 +test text-20.77 {TextSearchCmd, hidden text shouldn't influence start index} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 tag configure hidden -elide true + .t2 tag add hidden 1.0 1.2 + .t2 search -regexp bar 1.3 +} 1.3 +test text-20.78 {TextSearchCmd, hidden text inside match must count in length} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 tag configure hidden -elide true + .t2 tag add hidden 1.2 1.4 + list [.t2 search -regexp -count foo foar 1.3] $foo +} {1.0 6} +test text-20.78.1 {TextSearchCmd, hidden text inside match must count in length} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 tag configure hidden -elide true + .t2 tag add hidden 1.2 1.4 + list [.t2 search -count foo foar 1.3] $foo +} {1.0 6} +test text-20.78.2 {TextSearchCmd, hidden text inside match must count in length} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 tag configure hidden -elide true + .t2 tag add hidden 1.2 1.4 + .t2 search -strict -count foo foar 1.3 +} {} +test text-20.78.3 {TextSearchCmd, hidden text inside match must count in length} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoar" + .t2 tag configure hidden -elide true + .t2 tag add hidden 1.2 1.4 + .t2 tag add hidden 2.2 2.4 + list [.t2 search -regexp -all -count foo foar 1.3] $foo +} {{2.0 3.0 1.0} {6 4 6}} +test text-20.78.4 {TextSearchCmd, hidden text inside match must count in length} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoar" + .t2 tag configure hidden -elide true + .t2 tag add hidden 1.2 1.4 + .t2 tag add hidden 2.2 2.4 + list [.t2 search -all -count foo foar 1.3] $foo +} {{2.0 3.0 1.0} {6 4 6}} +test text-20.78.5 {TextSearchCmd, hidden text inside match must count in length} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoar" + .t2 tag configure hidden -elide true + .t2 tag add hidden 1.2 1.4 + .t2 tag add hidden 2.2 2.4 + list [.t2 search -strict -all -count foo foar 1.3] $foo +} {{2.0 3.0} {6 4}} +test text-20.78.6 {TextSearchCmd, single line with -all} { + deleteWindows + pack [text .t2] + .t2 insert end " X\n X\n X\n X\n X\n X\n" + .t2 search -all -regexp { +| *\n} 1.0 end +} {1.0 1.2 2.0 2.2 3.0 3.2 4.0 4.2 5.0 5.2 6.0 6.2 7.0} +test text-20.79 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -count foo foobar\nfoo 1.0] $foo +} {1.0 10} +test text-20.80 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -count foo bar\nfoo 1.0] $foo +} {1.3 7} +test text-20.81 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -count foo \nfoo 1.0] $foo +} {1.6 4} +test text-20.82 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -count foo bar\nfoobar\nfoo 1.0] $foo +} {1.3 14} +test text-20.83 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 search -count foo bar\nfoobar\nfoobanearly 1.0 +} {} +test text-20.84 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -regexp -count foo foobar\nfoo 1.0] $foo +} {1.0 10} +test text-20.85 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -regexp -count foo bar\nfoo 1.0] $foo +} {1.3 7} +test text-20.86 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -regexp -count foo \nfoo 1.0] $foo +} {1.6 4} +test text-20.87 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -regexp -count foo bar\nfoobar\nfoo 1.0] $foo +} {1.3 14} +test text-20.88 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 search -regexp -count foo bar\nfoobar\nfoobanearly 1.0 +} {} +test text-20.89 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfaoobar\nfoobar" + .t2 search -regexp -count foo bar\nfoo 1.0 +} {2.4} +test text-20.90 {TextSearchCmd, multiline matching end of window} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfaoobar\nfoobar" + .t2 search -regexp -count foo bar\nfoobar\n\n 1.0 +} {} +test text-20.91 {TextSearchCmd, multiline matching end of window} { + deleteWindows + pack [text .t2] + .t2 search "\n\n" 1.0 +} {} +test text-20.92 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -backwards -count foo foobar\nfoo end] $foo +} {2.0 10} +test text-20.93 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -backwards -count foo bar\nfoo 1.0] $foo +} {2.3 7} +test text-20.94 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -backwards -count foo \nfoo 1.0] $foo +} {2.6 4} +test text-20.95 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -backwards -count foo bar\nfoobar\nfoo 1.0] $foo +} {1.3 14} +test text-20.96 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 search -backwards -count foo bar\nfoobar\nfoobanearly 1.0 +} {} +test text-20.97 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -backwards -regexp -count foo foobar\nfoo end] $foo +} {2.0 10} +test text-20.97.1 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -backwards -regexp -count foo foobar\nfo end] $foo +} {2.0 9} +test text-20.98 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -backwards -regexp -count foo bar\nfoo 1.0] $foo +} {2.3 7} +test text-20.99 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -backwards -regexp -count foo \nfoo 1.0] $foo +} {2.6 4} +test text-20.100 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + list [.t2 search -backwards -regexp -count foo bar\nfoobar\nfoo 1.0] $foo +} {1.3 14} +test text-20.101 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 search -backwards -regexp -count foo bar\nfoobar\nfoobanearly 1.0 +} {} +test text-20.102 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfaoobar\nfoobar" + .t2 search -backwards -regexp -count foo bar\nfoo 1.0 +} {2.4} +test text-20.103 {TextSearchCmd, multiline matching end of window} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfaoobar\nfoobar" + .t2 search -backwards -regexp -count foo bar\nfoobar\n\n 1.0 +} {} +test text-20.104 {TextSearchCmd, multiline matching end of window} { + deleteWindows + pack [text .t2] + .t2 search -backwards "\n\n" 1.0 +} {} +test text-20.105 {TextSearchCmd, multiline regexp matching} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 { Tcl_Obj *objPtr)); static Tcl_Obj* FSNormalizeAbsolutePath _ANSI_ARGS_((Tcl_Interp* interp, Tcl_Obj *pathPtr));} set markExpr "^(\[A-Za-z0-9~_\]+\[ \t\n\r\]*\\(|(\[^ \t\(#\n\r/@:\*\]\[^=\(\r\n\]*\[ \t\]+\\*?)?" append markExpr "(\[A-Za-z0-9~_\]+(<\[^>\]*>)?(::)?(\[A-Za-z0-9~_\]+::)*\[-A-Za-z0-9~_+ <>\|\\*/\]+|\[A-Za-z0-9~_\]+)" append markExpr "\[ \n\t\r\]*\\()" - .t search -forwards -regexp $markExpr 1.41 end -} -cleanup { - destroy .t -} -result {} -test text-22.120 {TextSearchCmd, multiline regexp matching} -body { -# Practical example which used to crash Tk, but only after the -# search is complete. This is memory corruption caused by -# a bug in Tcl's handling of string objects. -# (Tcl bug 635200) - pack [text .t] - .t insert 1.0 {static int SetFsPathFromAny _ANSI_ARGS_((Tcl_Interp *interp, + .t2 search -forwards -regexp $markExpr 1.41 end +} {} +test text-20.106 {TextSearchCmd, multiline regexp matching} { + # Practical example which used to crash Tk, but only after the + # search is complete. This is memory corruption caused by + # a bug in Tcl's handling of string objects. + # (Tcl bug 635200) + deleteWindows + pack [text .t2] + .t2 insert 1.0 {static int SetFsPathFromAny _ANSI_ARGS_((Tcl_Interp *interp, Tcl_Obj *objPtr)); static Tcl_Obj* FSNormalizeAbsolutePath _ANSI_ARGS_((Tcl_Interp* interp, Tcl_Obj *pathPtr));} set markExpr "^(\[A-Za-z0-9~_\]+\[ \t\n\r\]*\\(|(\[^ \t\(#\n\r/@:\*\]\[^=\(\r\n\]*\[ \t\]+\\*?)?" append markExpr "(\[A-Za-z0-9~_\]+(<\[^>\]*>)?(::)?(\[A-Za-z0-9~_\]+::)*\[-A-Za-z0-9~_+ <>\|\\*/\]+|\[A-Za-z0-9~_\]+)" append markExpr "\[ \n\t\r\]*\\()" - .t search -forwards -regexp $markExpr 1.41 end -} -cleanup { - destroy .t -} -result {} -test text-22.121 {TextSearchCmd, multiline regexp matching} -body { - pack [text .t] - .t insert 1.0 { + .t2 search -forwards -regexp $markExpr 1.41 end +} {} +test text-20.107 {TextSearchCmd, multiline regexp matching} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 { static int SetFsPathFromAny _ANSI_ARGS_((Tcl_Interp *interp, Tcl_Obj *objPtr)); static Tcl_Obj* FSNormalizeAbsolutePath @@ -4948,275 +2071,240 @@ static Tcl_Obj* FSNormalizeAbsolutePath set markExpr "^(\[A-Za-z0-9~_\]+\[ \t\n\r\]*\\(|(\[^ \t\(#\n\r/@:\*\]\[^=\(\r\n\]*\[ \t\]+\\*?)?" append markExpr "(\[A-Za-z0-9~_\]+(<\[^>\]*>)?(::)?(\[A-Za-z0-9~_\]+::)*\[-A-Za-z0-9~_+ <>\|\\*/\]+|\[A-Za-z0-9~_\]+)" append markExpr "\[ \n\t\r\]*\\()" - .t search -backwards -all -regexp $markExpr end -} -cleanup { - destroy .t -} -result {2.0} -test text-22.122 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t search -all -regexp -count foo bar\nfoo 1.0 -} -cleanup { - destroy .t -} -result {1.3 2.3} -test text-22.123 {TextSearchCmd, multiline matching} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t search -all -backwards -regexp -count foo bar\nfoo 1.0 -} -cleanup { - destroy .t -} -result {2.3 1.3} -test text-22.124 {TextSearchCmd, wrapping and limits} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t search -- "blah" 3.3 1.3 -} -cleanup { - destroy .t -} -result {} -test text-22.125 {TextSearchCmd, wrapping and limits} -body { - pack [text .t] - .t insert end "foobar\nfoobar\nfoobar" - .t search -backwards -- "blah" 1.3 3.3 -} -cleanup { - destroy .t -} -result {} -test text-22.126 {TextSearchCmd, wrapping and limits} -body { - pack [text .t] - .t insert end "if (stringPtr->uallocated > 0) \{x" - .t search -backwards -regexp -- "\[\]\")\}\[(\{\]" "1.32" 1.0 -} -cleanup { - destroy .t -} -result {1.31} -test text-22.127 {TextSearchCmd, wrapping and limits} -body { - pack [text .t] - .t insert end "if (stringPtr->uallocated > 0) \{x" - .t search -regexp -- "\[\]\")\}\[(\{\]" 1.30 "1.0 lineend" -} -cleanup { - destroy .t -} -result {1.31} -test text-22.128 {TextSearchCmd, wrapping and limits} -body { - pack [text .t] - .t insert end "if (stringPtr->uallocated > 0) \{x" - .t search -backwards -all -regexp -- "\[\]\")\}\[(\{\]" "1.32" 1.0 -} -cleanup { - destroy .t -} -result {1.31 1.29 1.3} -test text-22.129 {TextSearchCmd, wrapping and limits} -body { - pack [text .t] - .t insert end "if (stringPtr->uallocated > 0) \{x" - .t search -all -regexp -- "\[\]\")\}\[(\{\]" 1.0 "1.0 lineend" -} -cleanup { - destroy .t -} -result {1.3 1.29 1.31} -test text-22.130 {TextSearchCmd, wrapping and limits} -body { - pack [text .t] - .t insert end "if (stringPtr->uallocated > 0) \{x" - .t search -backwards -- "\{" "1.32" 1.0 -} -cleanup { - destroy .t -} -result {1.31} -test text-22.131 {TextSearchCmd, wrapping and limits} -body { - pack [text .t] - .t insert end "if (stringPtr->uallocated > 0) \{x" - .t search -- "\{" 1.30 "1.0 lineend" -} -cleanup { - destroy .t -} -result {1.31} -test text-22.132 {TextSearchCmd, multiline regexp matching} -body { - pack [text .t] - .t insert 1.0 { + .t2 search -backwards -all -regexp $markExpr end +} {2.0} +test text-20.108 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 search -all -regexp -count foo bar\nfoo 1.0 +} {1.3 2.3} +test text-20.109 {TextSearchCmd, multiline matching} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 search -all -backwards -regexp -count foo bar\nfoo 1.0 +} {2.3 1.3} +test text-20.110 {TextSearchCmd, wrapping and limits} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 search -- "blah" 3.3 1.3 +} {} +test text-20.111 {TextSearchCmd, wrapping and limits} { + deleteWindows + pack [text .t2] + .t2 insert end "foobar\nfoobar\nfoobar" + .t2 search -backwards -- "blah" 1.3 3.3 +} {} +test text-20.112 {TextSearchCmd, wrapping and limits} { + deleteWindows + pack [text .t2] + .t2 insert end "if (stringPtr->uallocated > 0) \{x" + .t2 search -backwards -regexp -- "\[\]\")\}\[(\{\]" "1.32" 1.0 +} {1.31} +test text-20.113 {TextSearchCmd, wrapping and limits} { + deleteWindows + pack [text .t2] + .t2 insert end "if (stringPtr->uallocated > 0) \{x" + .t2 search -regexp -- "\[\]\")\}\[(\{\]" 1.30 "1.0 lineend" +} {1.31} +test text-20.114 {TextSearchCmd, wrapping and limits} { + deleteWindows + pack [text .t2] + .t2 insert end "if (stringPtr->uallocated > 0) \{x" + .t2 search -backwards -all -regexp -- "\[\]\")\}\[(\{\]" "1.32" 1.0 +} {1.31 1.29 1.3} +test text-20.115 {TextSearchCmd, wrapping and limits} { + deleteWindows + pack [text .t2] + .t2 insert end "if (stringPtr->uallocated > 0) \{x" + .t2 search -all -regexp -- "\[\]\")\}\[(\{\]" 1.0 "1.0 lineend" +} {1.3 1.29 1.31} +test text-20.116 {TextSearchCmd, wrapping and limits} { + deleteWindows + pack [text .t2] + .t2 insert end "if (stringPtr->uallocated > 0) \{x" + .t2 search -backwards -- "\{" "1.32" 1.0 +} {1.31} +test text-20.117 {TextSearchCmd, wrapping and limits} { + deleteWindows + pack [text .t2] + .t2 insert end "if (stringPtr->uallocated > 0) \{x" + .t2 search -- "\{" 1.30 "1.0 lineend" +} {1.31} +test text-20.118 {TextSearchCmd, multiline regexp matching} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 { void Tcl_SetObjLength(objPtr, length) register Tcl_Obj *objPtr; /* Pointer to object. This object must - * not currently be shared. */ + * not currently be shared. */ register int length; /* Number of bytes desired for string * representation of object, not including - * terminating null byte. */ + * terminating null byte. */ \{ char *new; } set markExpr "^(\[A-Za-z0-9~_\]+\[ \t\n\r\]*\\(|(\[^ \t\(#\n\r/@:\*\]\[^=\(\r\n\]*\[ \t\]+\\*?)?" append markExpr "(\[A-Za-z0-9~_\]+(<\[^>\]*>)?(::)?(\[A-Za-z0-9~_\]+::)*\[-A-Za-z0-9~_+ <>\|\\*/\]+|\[A-Za-z0-9~_\]+)" append markExpr "\[ \n\t\r\]*\\()" - .t search -all -regexp -- $markExpr 1.0 -} -cleanup { - destroy .t -} -result {4.0} -test text-22.133 {TextSearchCmd, multiline regexp matching} -body { - pack [text .t] - .t insert 1.0 "first line\nlast line of text" + .t2 search -all -regexp -- $markExpr 1.0 +} {4.0} +test text-20.119 {TextSearchCmd, multiline regexp matching} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "first line\nlast line of text" set markExpr {^[a-z]+} -# This should not match, and should not wrap - .t search -regexp -- $markExpr end end -} -cleanup { - destroy .t -} -result {} -test text-22.134 {TextSearchCmd, multiline regexp matching} -body { - pack [text .t] - .t insert 1.0 "first line\nlast line of text" + # This should not match, and should not wrap + .t2 search -regexp -- $markExpr end end +} {} +test text-20.120 {TextSearchCmd, multiline regexp matching} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "first line\nlast line of text" set markExpr {^[a-z]+} -# This should not match, and should not wrap - .t search -regexp -- $markExpr end+10c end -} -cleanup { - destroy .t -} -result {} -test text-22.135 {TextSearchCmd, multiline regexp matching} -body { - pack [text .t] - .t insert 1.0 "first line\nlast line of text" + # This should not match, and should not wrap + .t2 search -regexp -- $markExpr end+10c end +} {} +test text-20.121 {TextSearchCmd, multiline regexp matching} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "first line\nlast line of text" set markExpr {^[a-z]+} -# This should not match, and should not wrap - .t search -regexp -backwards -- $markExpr 1.0 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.136 {TextSearchCmd, regexp linestop} -body { - pack [text .t] - .t insert 1.0 "first line\nlast line of text" - .t search -regexp -- {i.*x} 1.0 -} -cleanup { - destroy .t -} -result {2.6} -test text-22.137 {TextSearchCmd, multiline regexp nolinestop matching} -body { - pack [text .t] - .t insert 1.0 "first line\nlast line of text" - .t search -regexp -nolinestop -- {i.*x} 1.0 -} -cleanup { - destroy .t -} -result {1.1} -test text-22.138 {TextSearchCmd, regexp linestop} -body { - pack [text .t] - .t insert 1.0 "first line\nlast line of text" - .t search -regexp -all -overlap -- {i.*x} 1.0 -} -cleanup { - destroy .t -} -result {2.6} -test text-22.139 {TextSearchCmd, regexp linestop} -body { - pack [text .t] - .t insert 1.0 "first line\nlast line of text" - .t search -regexp -all -- {i.*x} 1.0 -} -cleanup { - destroy .t -} -result {2.6} -test text-22.140 {TextSearchCmd, multiline regexp nolinestop matching} -body { - pack [text .t] - .t insert 1.0 "first line\nlast line of text" - list [.t search -regexp -all -overlap -count c -nolinestop -- {i.*x} 1.0] $c -} -cleanup { - destroy .t -} -result {{1.1 2.6} {26 10}} -test text-22.141 {TextSearchCmd, multiline regexp nolinestop matching} -body { - pack [text .t] - .t insert 1.0 "first line\nlast line of text" - list [.t search -regexp -all -count c -nolinestop -- {i.*x} 1.0] $c -} -cleanup { - destroy .t -} -result {1.1 26} -test text-22.142 {TextSearchCmd, stop at end of line} -body { - pack [text .t] - .t insert 1.0 " \t\n last line of text" - .t search -regexp -nolinestop -- {[^ \t]} 1.0 -} -cleanup { - destroy .t -} -result {1.3} -test text-22.143 {TextSearchCmd, overlapping all matches} -body { - pack [text .t] - .t insert 1.0 "abcde abcde" - list [.t search -regexp -all -overlap -count c -- {\w+} 1.0] $c -} -cleanup { - destroy .t -} -result {{1.0 1.6} {5 5}} -test text-22.144 {TextSearchCmd, non-overlapping all matches} -body { - pack [text .t] - .t insert 1.0 "abcde abcde" - list [.t search -regexp -all -count c -- {\w+} 1.0] $c -} -cleanup { - destroy .t -} -result {{1.0 1.6} {5 5}} -test text-22.145 {TextSearchCmd, stop at end of line} -body { - pack [text .t] - .t insert 1.0 "abcde abcde" - list [.t search -backwards -regexp -all -count c -- {\w+} 1.0] $c -} -cleanup { - destroy .t -} -result {{1.6 1.0} {5 5}} -test text-22.146 {TextSearchCmd, backwards search stop index } -body { - pack [text .t] - .t insert 1.0 "bla ZabcZdefZghi and some text again" - list [.t search -backwards -regexp -count c -- {Z\w+} 1.21 1.5] $c -} -cleanup { - destroy .t -} -result {1.8 8} -test text-22.147 {TextSearchCmd, backwards search stop index } -body { - pack [text .t] - .t insert 1.0 "bla ZabcZdefZghi and some text again" - list [.t search -backwards -all -overlap -regexp -count c -- {Z\w+} 1.21 1.5] $c -} -cleanup { - destroy .t -} -result {1.8 8} -test text-22.148 {TextSearchCmd, backwards search stop index } -body { - pack [text .t] - .t insert 1.0 "bla ZabcZdefZghi and some text again" - list [.t search -backwards -all -regexp -count c -- {Z\w+} 1.21 1.5] $c -} -cleanup { - destroy .t -} -result {1.8 8} -test text-22.149 {TextSearchCmd, backwards search stop index } -body { - pack [text .t] - .t insert 1.0 "bla ZabcZdefZghi and some text again" - list [.t search -backwards -overlap -all -regexp -count c -- {Z\w+} 1.21 1.1] $c -} -cleanup { - destroy .t -} -result {1.4 12} -test text-22.150 {TextSearchCmd, backwards search stop index } -body { - pack [text .t] - .t insert 1.0 "bla ZabcZdefZghi and some text again" - list [.t search -backwards -overlap -all -regexp -count c -- {Z[^Z]+Z} 1.21 1.1] $c -} -cleanup { - destroy .t -} -result {{1.8 1.4} {5 5}} -test text-22.151 {TextSearchCmd, backwards search stop index } -body { - pack [text .t] - .t insert 1.0 "bla ZabcZdefZghi and some text again" - list [.t search -backwards -all -regexp -count c -- {Z\w+} 1.21 1.1] $c -} -cleanup { - destroy .t -} -result {1.4 12} -test text-22.152 {TextSearchCmd, backwards search stop index } -body { - pack [text .t] - .t insert 1.0 "bla ZabcZdefZghi and some text again" - .t insert 1.0 "bla ZabcZdefZghi and some text again\n" - list [.t search -backwards -all -overlap -regexp -count c -- {Z\w+} 2.21 1.5] $c -} -cleanup { - destroy .t -} -result {{2.4 1.8} {12 8}} -test text-22.153 {TextSearchCmd, backwards search stop index } -body { - pack [text .t] - .t insert 1.0 "bla ZabcZdefZghi and some text again" - .t insert 1.0 "bla ZabcZdefZghi and some text again\n" - list [.t search -backwards -all -regexp -count c -- {Z\w+} 2.21 1.5] $c -} -cleanup { - destroy .t -} -result {{2.4 1.8} {12 8}} -test text-22.154 {TextSearchCmd, backwards search stop index } -body { - pack [text .t] - .t insert 1.0 "bla ZabcZdefZghi and some text again" - .t insert 1.0 "bla ZabcZdefZghi and some text again\n" - list [.t search -backwards -overlap -all -regexp -count c -- {Z\w+} 2.21 1.1] $c -} -cleanup { - destroy .t -} -result {{2.4 1.4} {12 12}} -test text-22.155 {TextSearchCmd, backwards search stop index } -body { - pack [text .t] - .t insert 1.0 "bla ZabcZdefZghi and some text again" - .t insert 1.0 "bla ZabcZdefZghi and some text again\n" - list [.t search -backwards -all -regexp -count c -- {Z\w+} 2.21 1.1] $c -} -cleanup { - destroy .t -} -result {{2.4 1.4} {12 12}} -test text-22.156 {TextSearchCmd, search -all example} -body { - pack [text .t] - .t insert 1.0 { + # This should not match, and should not wrap + .t2 search -regexp -backwards -- $markExpr 1.0 1.0 +} {} +test text-20.122 {TextSearchCmd, regexp linestop} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "first line\nlast line of text" + .t2 search -regexp -- {i.*x} 1.0 +} {2.6} +test text-20.123 {TextSearchCmd, multiline regexp nolinestop matching} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "first line\nlast line of text" + .t2 search -regexp -nolinestop -- {i.*x} 1.0 +} {1.1} +test text-20.124 {TextSearchCmd, regexp linestop} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "first line\nlast line of text" + .t2 search -regexp -all -overlap -- {i.*x} 1.0 +} {2.6} +test text-20.124.1 {TextSearchCmd, regexp linestop} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "first line\nlast line of text" + .t2 search -regexp -all -- {i.*x} 1.0 +} {2.6} +test text-20.125 {TextSearchCmd, multiline regexp nolinestop matching} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "first line\nlast line of text" + list [.t2 search -regexp -all -overlap -count c -nolinestop -- {i.*x} 1.0] $c +} {{1.1 2.6} {26 10}} +test text-20.125.1 {TextSearchCmd, multiline regexp nolinestop matching} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "first line\nlast line of text" + list [.t2 search -regexp -all -count c -nolinestop -- {i.*x} 1.0] $c +} {1.1 26} +test text-20.126 {TextSearchCmd, stop at end of line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 " \t\n last line of text" + .t2 search -regexp -nolinestop -- {[^ \t]} 1.0 +} {1.3} +test text-20.127 {TextSearchCmd, overlapping all matches} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde abcde" + list [.t2 search -regexp -all -overlap -count c -- {\w+} 1.0] $c +} {{1.0 1.6} {5 5}} +test text-20.127.1 {TextSearchCmd, non-overlapping all matches} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde abcde" + list [.t2 search -regexp -all -count c -- {\w+} 1.0] $c +} {{1.0 1.6} {5 5}} +test text-20.128 {TextSearchCmd, stop at end of line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde abcde" + list [.t2 search -backwards -regexp -all -count c -- {\w+} 1.0] $c +} {{1.6 1.0} {5 5}} +test text-20.129 {TextSearchCmd, backwards search stop index } { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "bla ZabcZdefZghi and some text again" + list [.t2 search -backwards -regexp -count c -- {Z\w+} 1.21 1.5] $c +} {1.8 8} +test text-20.130 {TextSearchCmd, backwards search stop index } { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "bla ZabcZdefZghi and some text again" + list [.t2 search -backwards -all -overlap -regexp -count c -- {Z\w+} 1.21 1.5] $c +} {1.8 8} +test text-20.130.1 {TextSearchCmd, backwards search stop index } { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "bla ZabcZdefZghi and some text again" + list [.t2 search -backwards -all -regexp -count c -- {Z\w+} 1.21 1.5] $c +} {1.8 8} +test text-20.131 {TextSearchCmd, backwards search stop index } { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "bla ZabcZdefZghi and some text again" + list [.t2 search -backwards -overlap -all -regexp -count c -- {Z\w+} 1.21 1.1] $c +} {1.4 12} +test text-20.131.1 {TextSearchCmd, backwards search stop index } { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "bla ZabcZdefZghi and some text again" + list [.t2 search -backwards -overlap -all -regexp -count c -- {Z[^Z]+Z} 1.21 1.1] $c +} {{1.8 1.4} {5 5}} +test text-20.131.2 {TextSearchCmd, backwards search stop index } { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "bla ZabcZdefZghi and some text again" + list [.t2 search -backwards -all -regexp -count c -- {Z\w+} 1.21 1.1] $c +} {1.4 12} +test text-20.132 {TextSearchCmd, backwards search stop index } { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "bla ZabcZdefZghi and some text again" + .t2 insert 1.0 "bla ZabcZdefZghi and some text again\n" + list [.t2 search -backwards -all -overlap -regexp -count c -- {Z\w+} 2.21 1.5] $c +} {{2.4 1.8} {12 8}} +test text-20.132.1 {TextSearchCmd, backwards search stop index } { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "bla ZabcZdefZghi and some text again" + .t2 insert 1.0 "bla ZabcZdefZghi and some text again\n" + list [.t2 search -backwards -all -regexp -count c -- {Z\w+} 2.21 1.5] $c +} {{2.4 1.8} {12 8}} +test text-20.133 {TextSearchCmd, backwards search stop index } { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "bla ZabcZdefZghi and some text again" + .t2 insert 1.0 "bla ZabcZdefZghi and some text again\n" + list [.t2 search -backwards -overlap -all -regexp -count c -- {Z\w+} 2.21 1.1] $c +} {{2.4 1.4} {12 12}} +test text-20.133.1 {TextSearchCmd, backwards search stop index } { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "bla ZabcZdefZghi and some text again" + .t2 insert 1.0 "bla ZabcZdefZghi and some text again\n" + list [.t2 search -backwards -all -regexp -count c -- {Z\w+} 2.21 1.1] $c +} {{2.4 1.4} {12 12}} +test text-20.134 {TextSearchCmd, search -all example} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 { See the package: supersearch for more information. @@ -5230,968 +2318,715 @@ See the package: marks for more information. } set pat {package: ([a-zA-Z0-9][-a-zA-Z0-9._+#/]*)} - list [.t search -nolinestop -regexp -nocase -all -forwards \ + list [.t2 search -nolinestop -regexp -nocase -all -forwards \ -count c -- $pat 1.0 end] $c -} -cleanup { - destroy .t -} -result {{3.8 6.8 8.0 11.8} {20 26 13 14}} -test text-22.157 {TextSearchCmd, backwards search overlaps} -body { - pack [text .t] - .t insert 1.0 "foobarfoobaaaaaaaaaaarfoo" - .t search -backwards -regexp {fooba+rfoo} end -} -cleanup { - destroy .t -} -result {1.6} -test text-22.158 {TextSearchCmd, backwards search overlaps} -body { - pack [text .t] - .t insert 1.0 "foobarfoobaaaaaaaaaaarfoo" - .t search -backwards -overlap -all -regexp {fooba+rfoo} end -} -cleanup { - destroy .t -} -result {1.6 1.0} -test text-22.159 {TextSearchCmd, backwards search overlaps} -body { - pack [text .t] - .t insert 1.0 "foobarfoobaaaaaaaaaaarfoo" - .t search -backwards -all -regexp {fooba+rfoo} end -} -cleanup { - destroy .t -} -result {1.6} -test text-22.160 {TextSearchCmd, forwards search overlaps} -body { - pack [text .t] - .t insert 1.0 "foobarfoobaaaaaaaaaaarfoo" - .t search -all -overlap -regexp {fooba+rfoo} end -} -cleanup { - destroy .t -} -result {1.0 1.6} -test text-22.161 {TextSearchCmd, forwards search overlaps} -body { - pack [text .t] - .t insert 1.0 "foobarfoobaaaaaaaaaaarfoo" - .t search -all -regexp {fooba+rfoo} end -} -cleanup { - destroy .t -} -result {1.0} -test text-22.162 {TextSearchCmd, forward exact search overlaps} -body { - pack [text .t] - .t insert 1.0 "abababab" - .t search -exact -overlap -all {abab} 1.0 -} -cleanup { - destroy .t -} -result {1.0 1.2 1.4} -test text-22.163 {TextSearchCmd, forward exact search overlaps} -body { - pack [text .t] - .t insert 1.0 "abababab" - .t search -exact -all {abab} 1.0 -} -cleanup { - destroy .t -} -result {1.0 1.4} -test text-22.164 {TextSearchCmd, backward exact search overlaps} -body { - pack [text .t] - .t insert 1.0 "ababababab" - .t search -exact -overlap -backwards -all {abab} end -} -cleanup { - destroy .t -} -result {1.6 1.4 1.2 1.0} -test text-22.165 {TextSearchCmd, backward exact search overlaps} -body { - pack [text .t] - .t insert 1.0 "ababababab" - .t search -exact -backwards -all {abab} end -} -cleanup { - destroy .t -} -result {1.6 1.2} -test text-22.166 {TextSearchCmd, backward exact search overlaps} -body { - pack [text .t] - .t insert 1.0 "abababababab" - .t search -exact -backwards -all {abab} end -} -cleanup { - destroy .t -} -result {1.8 1.4 1.0} -test text-22.167 {TextSearchCmd, forward exact search overlaps} -body { - pack [text .t] - .t insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" - .t search -exact -overlap -all "foo\nbar\nfoo" 1.0 -} -cleanup { - destroy .t -} -result {1.0 3.0 5.0} -test text-22.168 {TextSearchCmd, forward exact search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" - .t search -exact -all "foo\nbar\nfoo" 1.0 -} -cleanup { - destroy .t -} -result {1.0 5.0} -test text-22.169 {TextSearchCmd, backward exact search overlaps} -body { - pack [text .t] - .t insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" - .t search -exact -overlap -backward -all "foo\nbar\nfoo" end -} -cleanup { - destroy .t -} -result {5.0 3.0 1.0} -test text-22.170 {TextSearchCmd, backward exact search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" - .t search -exact -backward -all "foo\nbar\nfoo" end -} -cleanup { - destroy .t -} -result {5.0 1.0} -test text-22.171 {TextSearchCmd, backward exact search overlaps} -body { - pack [text .t] - .t insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" - .t search -regexp -backward -overlap -all "foo\nbar\nfoo" end -} -cleanup { - destroy .t -} -result {5.0 3.0 1.0} -test text-22.172 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" - .t search -regexp -backward -all "foo\nbar\nfoo" end -} -cleanup { - destroy .t -} -result {5.0 1.0} -test text-22.173 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 " aasda asdj werwer" - .t search -regexp -backward -- {(\$)?[\w:_]+} 1.9 -} -cleanup { - destroy .t -} -result {1.7} -test text-22.174 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 " aasda asdj werwer" - .t search -regexp -backward -- {(\$)?[\w:_]+} 1.9 1.5 -} -cleanup { - destroy .t -} -result {1.7} -test text-22.175 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 " aasda asdj werwer" - .t search -regexp -backward -- {(\$)?[\w:_]+} 1.9 1.7 -} -cleanup { - destroy .t -} -result {1.7} -test text-22.176 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 " aasda asdj werwer" - .t search -regexp -backward -- {(\$)?[\w:_]+} 1.9 1.8 -} -cleanup { - destroy .t -} -result {1.8} -test text-22.177 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 " aasda asdj werwer" - .t search -regexp -backward -all -- {(\$)?[\w:_]+} 1.9 1.3 -} -cleanup { - destroy .t -} -result {1.7 1.3} -test text-22.178 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 " aasda asdj werwer" - .t search -regexp -backward -all -- {(\$)?[\w:_]+} 1.9 1.13 -} -cleanup { - destroy .t -} -result {} -test text-22.179 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 " aasda asdj werwer" - .t search -regexp -backward -all -- {(\$)?[\w:_]+} 2.0 1.3 -} -cleanup { - destroy .t -} -result {1.12 1.7 1.3} -test text-22.180 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 " aasda asdj werwer" - .t search -regexp -backward -all -- {(\$)?[\w:_]+} 1.3 -} -cleanup { - destroy .t -} -result {1.1 1.12 1.7 1.3} -test text-22.181 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\n" - .t search -regexp -backward -all -- {(\w+\n)+} end -} -cleanup { - destroy .t -} -result {1.0} -test text-22.182 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\n" - .t search -regexp -backward -all -- {(\w+\n)+} end 1.5 -} -cleanup { - destroy .t -} -result {2.0} -test text-22.183 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - .t search -regexp -backward -all -- {(\w+\n\w)+} end 1.5 -} -cleanup { - destroy .t -} -result {2.0} -test text-22.184 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - list [.t search -regexp -all -count foo -- {(\w+\n)+} 1.0] $foo -} -cleanup { - destroy .t -} -result {1.0 20} -test text-22.185 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" +} {{3.8 6.8 8.0 11.8} {20 26 13 14}} +test text-20.135 {TextSearchCmd, backwards search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "foobarfoobaaaaaaaaaaarfoo" + .t2 search -backwards -regexp {fooba+rfoo} end +} {1.6} +test text-20.135.1 {TextSearchCmd, backwards search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "foobarfoobaaaaaaaaaaarfoo" + .t2 search -backwards -overlap -all -regexp {fooba+rfoo} end +} {1.6 1.0} +test text-20.135.2 {TextSearchCmd, backwards search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "foobarfoobaaaaaaaaaaarfoo" + .t2 search -backwards -all -regexp {fooba+rfoo} end +} {1.6} +test text-20.135.3 {TextSearchCmd, forwards search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "foobarfoobaaaaaaaaaaarfoo" + .t2 search -all -overlap -regexp {fooba+rfoo} end +} {1.0 1.6} +test text-20.135.4 {TextSearchCmd, forwards search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "foobarfoobaaaaaaaaaaarfoo" + .t2 search -all -regexp {fooba+rfoo} end +} {1.0} +test text-20.136 {TextSearchCmd, forward exact search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abababab" + .t2 search -exact -overlap -all {abab} 1.0 +} {1.0 1.2 1.4} +test text-20.136.1 {TextSearchCmd, forward exact search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abababab" + .t2 search -exact -all {abab} 1.0 +} {1.0 1.4} +test text-20.137 {TextSearchCmd, backward exact search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "ababababab" + .t2 search -exact -overlap -backwards -all {abab} end +} {1.6 1.4 1.2 1.0} +test text-20.137.1 {TextSearchCmd, backward exact search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "ababababab" + .t2 search -exact -backwards -all {abab} end +} {1.6 1.2} +test text-20.137.2 {TextSearchCmd, backward exact search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abababababab" + .t2 search -exact -backwards -all {abab} end +} {1.8 1.4 1.0} +test text-20.138 {TextSearchCmd, forward exact search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" + .t2 search -exact -overlap -all "foo\nbar\nfoo" 1.0 +} {1.0 3.0 5.0} +test text-20.138.1 {TextSearchCmd, forward exact search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" + .t2 search -exact -all "foo\nbar\nfoo" 1.0 +} {1.0 5.0} +test text-20.139 {TextSearchCmd, backward exact search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" + .t2 search -exact -overlap -backward -all "foo\nbar\nfoo" end +} {5.0 3.0 1.0} +test text-20.140 {TextSearchCmd, backward exact search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" + .t2 search -exact -backward -all "foo\nbar\nfoo" end +} {5.0 1.0} +test text-20.141 {TextSearchCmd, backward exact search overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" + .t2 search -regexp -backward -overlap -all "foo\nbar\nfoo" end +} {5.0 3.0 1.0} +test text-20.142 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "foo\nbar\nfoo\nbar\nfoo\nbar\nfoo\n" + .t2 search -regexp -backward -all "foo\nbar\nfoo" end +} {5.0 1.0} +test text-20.142a {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 " aasda asdj werwer" + .t2 search -regexp -backward -- {(\$)?[\w:_]+} 1.9 +} {1.7} +test text-20.143 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 " aasda asdj werwer" + .t2 search -regexp -backward -- {(\$)?[\w:_]+} 1.9 1.5 +} {1.7} +test text-20.144 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 " aasda asdj werwer" + .t2 search -regexp -backward -- {(\$)?[\w:_]+} 1.9 1.7 +} {1.7} +test text-20.145 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 " aasda asdj werwer" + .t2 search -regexp -backward -- {(\$)?[\w:_]+} 1.9 1.8 +} {1.8} +test text-20.146 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 " aasda asdj werwer" + .t2 search -regexp -backward -all -- {(\$)?[\w:_]+} 1.9 1.3 +} {1.7 1.3} +test text-20.147 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 " aasda asdj werwer" + .t2 search -regexp -backward -all -- {(\$)?[\w:_]+} 1.9 1.13 +} {} +test text-20.148 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 " aasda asdj werwer" + .t2 search -regexp -backward -all -- {(\$)?[\w:_]+} 2.0 1.3 +} {1.12 1.7 1.3} +test text-20.149 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 " aasda asdj werwer" + .t2 search -regexp -backward -all -- {(\$)?[\w:_]+} 1.3 +} {1.1 1.12 1.7 1.3} +test text-20.150 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\n" + .t2 search -regexp -backward -all -- {(\w+\n)+} end +} {1.0} +test text-20.151 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\n" + .t2 search -regexp -backward -all -- {(\w+\n)+} end 1.5 +} {2.0} +test text-20.152 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + .t2 search -regexp -backward -all -- {(\w+\n\w)+} end 1.5 +} {2.0} +test text-20.153 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + list [.t2 search -regexp -all -count foo -- {(\w+\n)+} 1.0] $foo +} {1.0 20} +test text-20.154 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" set res {} lappend res \ - [list [.t search -regexp -all -count foo -- {(\w+\n)+} 1.0] $foo] \ - [list [.t search -regexp -all -count foo -- {(\w+)+} 1.0] $foo] -} -cleanup { - destroy .t -} -result {{1.0 20} {{1.0 2.0 3.0 4.0} {5 5 5 1}}} -test text-22.186 {TextSearchCmd, regexp search greedy} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - list [.t search -regexp -all -nolinestop -count foo -- {.*} 1.0] $foo -} -cleanup { - destroy .t -} -result {1.0 20} -test text-22.187 {TextSearchCmd, regexp search greedy} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - list [.t search -regexp -all -count foo -- {.*} 1.0] $foo -} -cleanup { - destroy .t -} -result {{1.0 2.0 3.0 4.0} {5 5 5 1}} -test text-22.188 {TextSearchCmd, regexp search greedy multi-line} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - list [.t search -regexp -count foo -- {(\w+\n\w)+} 1.0] $foo -} -cleanup { - destroy .t -} -result {1.0 19} -test text-22.189 {TextSearchCmd, regexp search greedy multi-line} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - list [.t search -regexp -backwards -count foo -- {(\w+\n\w)+} end] $foo -} -cleanup { - destroy .t -} -result {1.0 19} -test text-22.190 {TextSearchCmd, regexp search greedy multi-line} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - list [.t search -regexp -all -backwards -count foo -- {(\w+\n\w)+} end] $foo -} -cleanup { - destroy .t -} -result {1.0 19} -test text-22.191 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - .t search -regexp -backward -all -- {(\w+\n\w)+} end 1.5 -} -cleanup { - destroy .t -} -result {2.0} -test text-22.192 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - .t search -regexp -backward -all -- {(\w+\n\w)+} end 1.3 -} -cleanup { - destroy .t -} -result {1.3} -test text-22.193 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - list [.t search -regexp -forward -count foo -- {(\w+\n\w)+} 1.3] $foo -} -cleanup { - destroy .t -} -result {1.3 16} -test text-22.194 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - list [.t search -regexp -forward -all -count foo -- {(\w+\n\w)+} 1.3] $foo -# This result is somewhat debatable -- the two results do overlap, -# but only because the search has totally wrapped around back to -# the start. -} -cleanup { - destroy .t -} -result {{1.3 1.0} {16 19}} -test text-22.195 {TextSearchCmd, backward regexp search no-overlaps} -body { - pack [text .t] - .t insert 1.0 "abcde\nabcde\nabcde\na" - list [.t search -regexp -forward -all -count foo -- {(\w+\n\w)+} 1.0 1.3] $foo -} -cleanup { - destroy .t -} -result {1.0 19} -test text-22.196 {TextSearchCmd, regexp search multi-line} -body { - pack [text .t] - .t insert 1.0 "aaaa\nbbbb\naaaa\nbbbb\n" - list [.t search -regexp -forward -all -count foo -- {(a+\n(b+\n))+} 1.0] $foo -} -cleanup { - destroy .t -} -result {1.0 20} -test text-22.197 {TextSearchCmd, regexp search complex cases} -body { - pack [text .t] - .t insert 1.0 "aaaa\nbbbb\naaaa\nbbbb\n" - list [.t search -regexp -forward -all -count foo \ + [list [.t2 search -regexp -all -count foo -- {(\w+\n)+} 1.0] $foo] \ + [list [.t2 search -regexp -all -count foo -- {(\w+)+} 1.0] $foo] +} {{1.0 20} {{1.0 2.0 3.0 4.0} {5 5 5 1}}} +test text-20.155 {TextSearchCmd, regexp search greedy} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + list [.t2 search -regexp -all -nolinestop -count foo -- {.*} 1.0] $foo +} {1.0 20} +test text-20.156 {TextSearchCmd, regexp search greedy} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + list [.t2 search -regexp -all -count foo -- {.*} 1.0] $foo +} {{1.0 2.0 3.0 4.0} {5 5 5 1}} +test text-20.157 {TextSearchCmd, regexp search greedy multi-line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + list [.t2 search -regexp -count foo -- {(\w+\n\w)+} 1.0] $foo +} {1.0 19} +test text-20.158 {TextSearchCmd, regexp search greedy multi-line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + list [.t2 search -regexp -backwards -count foo -- {(\w+\n\w)+} end] $foo +} {1.0 19} +test text-20.159 {TextSearchCmd, regexp search greedy multi-line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + list [.t2 search -regexp -all -backwards -count foo -- {(\w+\n\w)+} end] $foo +} {1.0 19} +test text-20.160 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + .t2 search -regexp -backward -all -- {(\w+\n\w)+} end 1.5 +} {2.0} +test text-20.161 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + .t2 search -regexp -backward -all -- {(\w+\n\w)+} end 1.3 +} {1.3} +test text-20.162 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + list [.t2 search -regexp -forward -count foo -- {(\w+\n\w)+} 1.3] $foo +} {1.3 16} +test text-20.163 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + list [.t2 search -regexp -forward -all -count foo -- {(\w+\n\w)+} 1.3] $foo + # This result is somewhat debatable -- the two results do overlap, + # but only because the search has totally wrapped around back to + # the start. +} {{1.3 1.0} {16 19}} +test text-20.164 {TextSearchCmd, backward regexp search no-overlaps} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "abcde\nabcde\nabcde\na" + list [.t2 search -regexp -forward -all -count foo -- {(\w+\n\w)+} 1.0 1.3] $foo +} {1.0 19} +test text-20.165 {TextSearchCmd, regexp search multi-line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "aaaa\nbbbb\naaaa\nbbbb\n" + list [.t2 search -regexp -forward -all -count foo -- {(a+\n(b+\n))+} 1.0] $foo +} {1.0 20} +test text-20.166 {TextSearchCmd, regexp search complex cases} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "aaaa\nbbbb\naaaa\nbbbb\n" + list [.t2 search -regexp -forward -all -count foo \ -- {(a+\n(b+\n))+} 1.0] $foo -} -cleanup { - destroy .t -} -result {1.0 20} -test text-22.198 {TextSearchCmd, regexp search multi-line} -body { - pack [text .t] - .t insert 1.0 "aaaa\nbbbb\ncccc\nbbbb\naaaa\n" +} {1.0 20} +test text-20.167 {TextSearchCmd, regexp search multi-line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "aaaa\nbbbb\ncccc\nbbbb\naaaa\n" set foo {} - list [.t search -regexp -forward -all -count foo \ + list [.t2 search -regexp -forward -all -count foo \ -- {(b+\nc+\nb+)\na+} 1.0] $foo -} -cleanup { - destroy .t -} -result {2.0 19} -test text-22.199 {TextSearchCmd, regexp search multi-line} -constraints { - knownBug -} -body { - pack [text .t] - .t insert 1.0 "aaaa\nbbbb\ncccc\nbbbb\naaaa\n" +} {2.0 19} +test text-20.168 {TextSearchCmd, regexp search multi-line} {knownBug} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "aaaa\nbbbb\ncccc\nbbbb\naaaa\n" set foo {} - list [.t search -regexp -forward -all -count foo \ + list [.t2 search -regexp -forward -all -count foo \ -- {(a+|b+\nc+\nb+)\na+} 1.0] $foo -} -cleanup { - destroy .t -} -result {2.0 19} -test text-22.200 {TextSearchCmd, regexp search multi-line} -constraints { - knownBug -} -body { - pack [text .t] - .t insert 1.0 "aaaa\nbbbb\ncccc\nbbbb\naaaa\n" +} {2.0 19} +test text-20.169 {TextSearchCmd, regexp search multi-line} {knownBug} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "aaaa\nbbbb\ncccc\nbbbb\naaaa\n" set foo {} - list [.t search -regexp -forward -all -count foo \ + list [.t2 search -regexp -forward -all -count foo \ -- {(a+|b+\nc+\nb+)+\na+} 1.0] $foo -} -cleanup { - destroy .t -} -result {2.0 19} -test text-22.201 {TextSearchCmd, regexp search multi-line} -body { - pack [text .t] - .t insert 1.0 "aaaa\nbbbb\ncccc\nbbbb\naaaa\n" +} {2.0 19} +test text-20.170 {TextSearchCmd, regexp search multi-line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "aaaa\nbbbb\ncccc\nbbbb\naaaa\n" set foo {} - list [.t search -regexp -forward -all -count foo \ + list [.t2 search -regexp -forward -all -count foo \ -- {((a+|b+\nc+\nb+)+\n)+a+} 1.0] $foo -} -cleanup { - destroy .t -} -result {1.0 24} -test text-22.202 {TextSearchCmd, regexp search multi-line} -constraints { - knownBug -} -body { - pack [text .t] - .t insert 1.0 "aaaa\nbbbb\nbbbb\nbbbb\nbbbb\n" - list [.t search -regexp -backward -all -count foo \ +} {1.0 24} +test text-20.171 {TextSearchCmd, regexp search multi-line} {knownBug} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "aaaa\nbbbb\nbbbb\nbbbb\nbbbb\n" + list [.t2 search -regexp -backward -all -count foo \ -- {b+\n|a+\n(b+\n)+} end] $foo -} -cleanup { - destroy .t -} -result {1.0 25} -test text-22.203 {TextSearchCmd, regexp search multi-line} -constraints { - knownBug -} -body { - pack [text .t] - .t insert 1.0 "aaaa\nbbbb\nbbbb\nbbbb\nbbbb\n" - .t search -regexp -backward -- {b+\n|a+\n(b+\n)+} end -# Should match at 1.0 for a true greedy match -} -cleanup { - destroy .t -} -result {1.0} -test text-22.204 {TextSearchCmd, regexp search multi-line} -body { - pack [text .t] - .t insert 1.0 "line0\nline1\nline1\nline1\nline1\nline2\nline2\nline2\nline3\n" - .t search -nolinestop -regexp -nocase -forwards -- {^(.*)\n(\1\n)+} 1.0 end -# Matches at 6.0 currently -} -cleanup { - destroy .t -} -result {2.0} -test text-22.205 {TextSearchCmd, regexp search multi-line} -setup { - pack [text .t] +} {1.0 25} +test text-20.172 {TextSearchCmd, regexp search multi-line} {knownBug} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "aaaa\nbbbb\nbbbb\nbbbb\nbbbb\n" + .t2 search -regexp -backward -- {b+\n|a+\n(b+\n)+} end + # Should match at 1.0 for a true greedy match +} {1.0} +test text-20.172.1 {TextSearchCmd, regexp search multi-line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "line0\nline1\nline1\nline1\nline1\nline2\nline2\nline2\nline3\n" + .t2 search -nolinestop -regexp -nocase -forwards -- {^(.*)\n(\1\n)+} 1.0 end + # Matches at 6.0 currently +} {2.0} +test text-20.173 {TextSearchCmd, regexp search multi-line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "\naaaxxx\nyyy\n" set res {} -} -body { - .t insert 1.0 "\naaaxxx\nyyy\n" - lappend res [.t search -count c -regexp -- {x*\ny*} 2.0] $c - lappend res [.t search -count c -regexp -- {x*\ny*} 2.1] $c - return $res -} -cleanup { - destroy .t -} -result {2.3 7 2.3 7} -test text-22.206 {TextSearchCmd, regexp search multi-line} -setup { - pack [text .t] - set res {} -} -body { - .t insert 1.0 "\naaa\n\n\n\n\nxxx\n" - lappend res [.t search -count c -regexp -- {\n+} 2.0] $c - lappend res [.t search -count c -regexp -- {\n+} 2.1] $c - return $res -} -cleanup { - destroy .t -} -result {2.3 5 2.3 5} -test text-22.207 {TextSearchCmd, regexp search multi-line} -setup { - pack [text .t] + lappend res [.t2 search -count c -regexp -- {x*\ny*} 2.0] $c + lappend res [.t2 search -count c -regexp -- {x*\ny*} 2.1] $c + set res +} {2.3 7 2.3 7} +test text-20.174 {TextSearchCmd, regexp search multi-line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "\naaa\n\n\n\n\nxxx\n" set res {} -} -body { - .t insert 1.0 "\naaa\n\n\t \n\t\t\t \n\nxxx\n" - lappend res [.t search -count c -regexp -- {(\n+(\t+ *)*)+} 2.0] $c - return $res -} -cleanup { - destroy .t -} -result {2.3 13} -test text-22.208 {TextSearchCmd, empty search range} -body { - pack [text .t] - .t insert 1.0 "a\na\na\n" - .t search -- a 2.0 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.209 {TextSearchCmd, empty search range} -body { - pack [text .t] - .t insert 1.0 "a\na\na\n" - .t search -backwards -- a 1.0 2.0 -} -cleanup { - destroy .t -} -result {} -test text-22.210 {TextSearchCmd, empty search range} -body { - pack [text .t] - .t insert 1.0 "a\na\na\n" - .t search -- a 1.0 1.0 -} -cleanup { - destroy .t -} -result {} -test text-22.211 {TextSearchCmd, empty search range} -body { - pack [text .t] - .t insert 1.0 "a\na\na\n" - .t search -backwards -- a 2.0 2.0 -} -cleanup { - destroy .t -} -result {} -test text-22.212 {TextSearchCmd, elide up to match} -setup { - pack [text .t] + lappend res [.t2 search -count c -regexp -- {\n+} 2.0] $c + lappend res [.t2 search -count c -regexp -- {\n+} 2.1] $c + set res +} {2.3 5 2.3 5} +test text-20.175 {TextSearchCmd, regexp search multi-line} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "\naaa\n\n\t \n\t\t\t \n\nxxx\n" set res {} -} -body { - .t insert 1.0 "a\nb\nc" - .t tag configure e -elide 1 - lappend res [.t search -regexp a 1.0] - lappend res [.t search -regexp b 1.0] - lappend res [.t search -regexp c 1.0] - .t tag add e 1.0 2.0 - lappend res [.t search -regexp a 1.0] - lappend res [.t search -regexp b 1.0] - lappend res [.t search -regexp c 1.0] - lappend res [.t search -elide -regexp a 1.0] - lappend res [.t search -elide -regexp b 1.0] - lappend res [.t search -elide -regexp c 1.0] -} -cleanup { - destroy .t -} -result {1.0 2.0 3.0 {} 2.0 3.0 1.0 2.0 3.0} -test text-22.213 {TextSearchCmd, elide up to match, backwards} -setup { - pack [text .t] + lappend res [.t2 search -count c -regexp -- {(\n+(\t+ *)*)+} 2.0] $c + set res +} {2.3 13} +test text-20.176 {TextSearchCmd, empty search range} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "a\na\na\n" + .t2 search -- a 2.0 1.0 +} {} +test text-20.177 {TextSearchCmd, empty search range} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "a\na\na\n" + .t2 search -backwards -- a 1.0 2.0 +} {} +test text-20.178 {TextSearchCmd, empty search range} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "a\na\na\n" + .t2 search -- a 1.0 1.0 +} {} +test text-20.179 {TextSearchCmd, empty search range} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "a\na\na\n" + .t2 search -backwards -- a 2.0 2.0 +} {} +test text-20.180 {TextSearchCmd, elide up to match} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "a\nb\nc" + .t2 tag configure e -elide 1 set res {} -} -body { - .t insert 1.0 "a\nb\nc" - .t tag configure e -elide 1 - lappend res [.t search -backward -regexp a 1.0] - lappend res [.t search -backward -regexp b 1.0] - lappend res [.t search -backward -regexp c 1.0] - .t tag add e 1.0 2.0 - lappend res [.t search -backward -regexp a 1.0] - lappend res [.t search -backward -regexp b 1.0] - lappend res [.t search -backward -regexp c 1.0] - lappend res [.t search -backward -elide -regexp a 1.0] - lappend res [.t search -backward -elide -regexp b 1.0] - lappend res [.t search -backward -elide -regexp c 1.0] -} -cleanup { - destroy .t -} -result {1.0 2.0 3.0 {} 2.0 3.0 1.0 2.0 3.0} -test text-22.214 {TextSearchCmd, elide up to match} -setup { - pack [text .t] + lappend res [.t2 search -regexp a 1.0] + lappend res [.t2 search -regexp b 1.0] + lappend res [.t2 search -regexp c 1.0] + .t2 tag add e 1.0 2.0 + lappend res [.t2 search -regexp a 1.0] + lappend res [.t2 search -regexp b 1.0] + lappend res [.t2 search -regexp c 1.0] + lappend res [.t2 search -elide -regexp a 1.0] + lappend res [.t2 search -elide -regexp b 1.0] + lappend res [.t2 search -elide -regexp c 1.0] +} {1.0 2.0 3.0 {} 2.0 3.0 1.0 2.0 3.0} +test text-20.181 {TextSearchCmd, elide up to match, backwards} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "a\nb\nc" + .t2 tag configure e -elide 1 set res {} -} -body { - .t insert 1.0 "a\nb\nc" - .t tag configure e -elide 1 - lappend res [.t search a 1.0] - lappend res [.t search b 1.0] - lappend res [.t search c 1.0] - .t tag add e 1.0 2.0 - lappend res [.t search a 1.0] - lappend res [.t search b 1.0] - lappend res [.t search c 1.0] - lappend res [.t search -elide a 1.0] - lappend res [.t search -elide b 1.0] - lappend res [.t search -elide c 1.0] -} -cleanup { - destroy .t -} -result {1.0 2.0 3.0 {} 2.0 3.0 1.0 2.0 3.0} -test text-22.215 {TextSearchCmd, elide up to match, backwards} -setup { - pack [text .t] + lappend res [.t2 search -backward -regexp a 1.0] + lappend res [.t2 search -backward -regexp b 1.0] + lappend res [.t2 search -backward -regexp c 1.0] + .t2 tag add e 1.0 2.0 + lappend res [.t2 search -backward -regexp a 1.0] + lappend res [.t2 search -backward -regexp b 1.0] + lappend res [.t2 search -backward -regexp c 1.0] + lappend res [.t2 search -backward -elide -regexp a 1.0] + lappend res [.t2 search -backward -elide -regexp b 1.0] + lappend res [.t2 search -backward -elide -regexp c 1.0] +} {1.0 2.0 3.0 {} 2.0 3.0 1.0 2.0 3.0} +test text-20.182 {TextSearchCmd, elide up to match} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "a\nb\nc" + .t2 tag configure e -elide 1 set res {} -} -body { - .t insert 1.0 "a\nb\nc" - .t tag configure e -elide 1 - lappend res [.t search -backward a 1.0] - lappend res [.t search -backward b 1.0] - lappend res [.t search -backward c 1.0] - .t tag add e 1.0 2.0 - lappend res [.t search -backward a 1.0] - lappend res [.t search -backward b 1.0] - lappend res [.t search -backward c 1.0] - lappend res [.t search -backward -elide a 1.0] - lappend res [.t search -backward -elide b 1.0] - lappend res [.t search -backward -elide c 1.0] -} -cleanup { - destroy .t -} -result {1.0 2.0 3.0 {} 2.0 3.0 1.0 2.0 3.0} -test text-22.216 {TextSearchCmd, elide up to match} -setup { - pack [text .t] + lappend res [.t2 search a 1.0] + lappend res [.t2 search b 1.0] + lappend res [.t2 search c 1.0] + .t2 tag add e 1.0 2.0 + lappend res [.t2 search a 1.0] + lappend res [.t2 search b 1.0] + lappend res [.t2 search c 1.0] + lappend res [.t2 search -elide a 1.0] + lappend res [.t2 search -elide b 1.0] + lappend res [.t2 search -elide c 1.0] +} {1.0 2.0 3.0 {} 2.0 3.0 1.0 2.0 3.0} +test text-20.183 {TextSearchCmd, elide up to match, backwards} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "a\nb\nc" + .t2 tag configure e -elide 1 set res {} -} -body { - .t insert 1.0 "aa\nbb\ncc" - .t tag configure e -elide 1 - lappend res [.t search ab 1.0] - lappend res [.t search bc 1.0] - .t tag add e 1.1 2.1 - lappend res [.t search ab 1.0] - lappend res [.t search b 1.0] - .t tag remove e 1.0 end - .t tag add e 2.1 3.1 - lappend res [.t search bc 1.0] - lappend res [.t search c 1.0] - .t tag remove e 1.0 end - .t tag add e 2.1 3.0 - lappend res [.t search bc 1.0] - lappend res [.t search c 1.0] -} -cleanup { - destroy .t -} -result {{} {} 1.0 2.1 2.0 3.1 2.0 3.0} -test text-22.217 {TextSearchCmd, elide up to match} -setup { - pack [text .t] + lappend res [.t2 search -backward a 1.0] + lappend res [.t2 search -backward b 1.0] + lappend res [.t2 search -backward c 1.0] + .t2 tag add e 1.0 2.0 + lappend res [.t2 search -backward a 1.0] + lappend res [.t2 search -backward b 1.0] + lappend res [.t2 search -backward c 1.0] + lappend res [.t2 search -backward -elide a 1.0] + lappend res [.t2 search -backward -elide b 1.0] + lappend res [.t2 search -backward -elide c 1.0] +} {1.0 2.0 3.0 {} 2.0 3.0 1.0 2.0 3.0} +test text-20.184 {TextSearchCmd, elide up to match} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "aa\nbb\ncc" + .t2 tag configure e -elide 1 set res {} -} -body { - .t insert 1.0 "aa\nbb\ncc" - .t tag configure e -elide 1 - lappend res [.t search -regexp ab 1.0] - lappend res [.t search -regexp bc 1.0] - .t tag add e 1.1 2.1 - lappend res [.t search -regexp ab 1.0] - lappend res [.t search -regexp b 1.0] - .t tag remove e 1.0 end - .t tag add e 2.1 3.1 - lappend res [.t search -regexp bc 1.0] - lappend res [.t search -regexp c 1.0] - .t tag remove e 1.0 end - .t tag add e 2.1 3.0 - lappend res [.t search -regexp bc 1.0] - lappend res [.t search -regexp c 1.0] -} -cleanup { - destroy .t -} -result {{} {} 1.0 2.1 2.0 3.1 2.0 3.0} -test text-22.217.1 {elide up to match, with UTF-8 chars before the match} -setup { - pack [text .t] + lappend res [.t2 search ab 1.0] + lappend res [.t2 search bc 1.0] + .t2 tag add e 1.1 2.1 + lappend res [.t2 search ab 1.0] + lappend res [.t2 search b 1.0] + .t2 tag remove e 1.0 end + .t2 tag add e 2.1 3.1 + lappend res [.t2 search bc 1.0] + lappend res [.t2 search c 1.0] + .t2 tag remove e 1.0 end + .t2 tag add e 2.1 3.0 + lappend res [.t2 search bc 1.0] + lappend res [.t2 search c 1.0] +} {{} {} 1.0 2.1 2.0 3.1 2.0 3.0} +test text-20.185 {TextSearchCmd, elide up to match} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "aa\nbb\ncc" + .t2 tag configure e -elide 1 set res {} -} -body { - .t tag configure e -elide 0 - .t insert end A {} xyz e bb\n - .t insert end \u00c4 {} xyz e bb + lappend res [.t2 search -regexp ab 1.0] + lappend res [.t2 search -regexp bc 1.0] + .t2 tag add e 1.1 2.1 + lappend res [.t2 search -regexp ab 1.0] + lappend res [.t2 search -regexp b 1.0] + .t2 tag remove e 1.0 end + .t2 tag add e 2.1 3.1 + lappend res [.t2 search -regexp bc 1.0] + lappend res [.t2 search -regexp c 1.0] + .t2 tag remove e 1.0 end + .t2 tag add e 2.1 3.0 + lappend res [.t2 search -regexp bc 1.0] + lappend res [.t2 search -regexp c 1.0] +} {{} {} 1.0 2.1 2.0 3.1 2.0 3.0} +test text-20.185.1 {TextSearchCmd, elide up to match, with UTF-8 chars before the match} { + deleteWindows + pack [text .t2] + .t2 tag configure e -elide 0 + .t2 insert end A {} xyz e bb\n + .t2 insert end \u00c4 {} xyz e bb set res {} - lappend res [.t search bb 1.0 "1.0 lineend"] - lappend res [.t search bb 2.0 "2.0 lineend"] - lappend res [.t search -regexp bb 1.0 "1.0 lineend"] - lappend res [.t search -regexp bb 2.0 "2.0 lineend"] - .t tag configure e -elide 1 - lappend res [.t search bb 1.0 "1.0 lineend"] - lappend res [.t search bb 2.0 "2.0 lineend"] - lappend res [.t search -regexp bb 1.0 "1.0 lineend"] - lappend res [.t search -regexp -elide bb 2.0 "2.0 lineend"] - lappend res [.t search -regexp bb 2.0 "2.0 lineend"] -} -cleanup { - destroy .t -} -result {1.4 2.4 1.4 2.4 1.4 2.4 1.4 2.4 2.4} -test text-22.218 {TextSearchCmd, strict limits} -body { - pack [text .t] - .t insert 1.0 "Hello world!\nThis is a test\n" - .t search -strictlimits -- "world" 1.3 1.8 -} -cleanup { - destroy .t -} -result {} -test text-22.219 {TextSearchCmd, strict limits} -body { - pack [text .t] - .t insert 1.0 "Hello world!\nThis is a test\n" - .t search -strictlimits -- "world" 1.3 1.10 -} -cleanup { - destroy .t -} -result {} -test text-22.220 {TextSearchCmd, strict limits} -body { - pack [text .t] - .t insert 1.0 "Hello world!\nThis is a test\n" - .t search -strictlimits -- "world" 1.3 1.11 -} -cleanup { - destroy .t -} -result {1.6} -test text-22.221 {TextSearchCmd, strict limits backwards} -body { - pack [text .t] - .t insert 1.0 "Hello world!\nThis is a test\n" - .t search -strictlimits -backward -- "world" 2.3 1.8 -} -cleanup { - destroy .t -} -result {} -test text-22.222 {TextSearchCmd, strict limits backwards} -body { - pack [text .t] - .t insert 1.0 "Hello world!\nThis is a test\n" - .t search -strictlimits -backward -- "world" 2.3 1.6 -} -cleanup { - destroy .t -} -result {1.6} -test text-22.223 {TextSearchCmd, strict limits backwards} -body { - pack [text .t] - .t insert 1.0 "Hello world!\nThis is a test\n" - .t search -strictlimits -backward -- "world" 2.3 1.7 -} -cleanup { - destroy .t -} -result {} -test text-22.224 {TextSearchCmd, strict limits} -body { - pack [text .t] - .t insert 1.0 "Hello world!\nThis is a test\n" - .t search -regexp -strictlimits -- "world" 1.3 1.8 -} -cleanup { - destroy .t -} -result {} -test text-22.225 {TextSearchCmd, strict limits} -body { - pack [text .t] - .t insert 1.0 "Hello world!\nThis is a test\n" - .t search -regexp -strictlimits -backward -- "world" 2.3 1.8 -} -cleanup { - destroy .t -} -result {} - - -test text-23.1 {TkTextGetTabs procedure} -setup { - text .t -highlightthickness 0 -bd 0 -relief flat -padx 0 -width 100 - pack .t -} -body { - .t insert end "1\t2\t3\t4\t55.5" - .t configure -tabs "\{{}" -} -cleanup { - destroy .t -} -returnCodes {error} -result {unmatched open brace in list} -test text-23.2 {TkTextGetTabs procedure} -setup { - text .t -highlightthickness 0 -bd 0 -relief flat -padx 0 -width 100 - pack .t -} -body { - .t insert end "1\t2\t3\t4\t55.5" - .t configure -tabs xyz -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad screen distance "xyz"} -test text-23.3 {TkTextGetTabs procedure} -setup { - text .t -highlightthickness 0 -bd 0 -relief flat -padx 0 -width 100 - pack .t -} -body { - .t insert end "1\t2\t3\t4\t55.5" - .t configure -tabs {100 200} + lappend res [.t2 search bb 1.0 "1.0 lineend"] + lappend res [.t2 search bb 2.0 "2.0 lineend"] + lappend res [.t2 search -regexp bb 1.0 "1.0 lineend"] + lappend res [.t2 search -regexp bb 2.0 "2.0 lineend"] + .t2 tag configure e -elide 1 + lappend res [.t2 search bb 1.0 "1.0 lineend"] + lappend res [.t2 search bb 2.0 "2.0 lineend"] + lappend res [.t2 search -regexp bb 1.0 "1.0 lineend"] + lappend res [.t2 search -regexp -elide bb 2.0 "2.0 lineend"] + lappend res [.t2 search -regexp bb 2.0 "2.0 lineend"] +} {1.4 2.4 1.4 2.4 1.4 2.4 1.4 2.4 2.4} +test text-20.186 {TextSearchCmd, strict limits} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "Hello world!\nThis is a test\n" + .t2 search -strictlimits -- "world" 1.3 1.8 +} {} +test text-20.187 {TextSearchCmd, strict limits} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "Hello world!\nThis is a test\n" + .t2 search -strictlimits -- "world" 1.3 1.10 +} {} +test text-20.188 {TextSearchCmd, strict limits} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "Hello world!\nThis is a test\n" + .t2 search -strictlimits -- "world" 1.3 1.11 +} {1.6} +test text-20.189 {TextSearchCmd, strict limits backwards} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "Hello world!\nThis is a test\n" + .t2 search -strictlimits -backward -- "world" 2.3 1.8 +} {} +test text-20.190 {TextSearchCmd, strict limits backwards} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "Hello world!\nThis is a test\n" + .t2 search -strictlimits -backward -- "world" 2.3 1.6 +} {1.6} +test text-20.191 {TextSearchCmd, strict limits backwards} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "Hello world!\nThis is a test\n" + .t2 search -strictlimits -backward -- "world" 2.3 1.7 +} {} +test text-20.192 {TextSearchCmd, strict limits} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "Hello world!\nThis is a test\n" + .t2 search -regexp -strictlimits -- "world" 1.3 1.8 +} {} +test text-20.193 {TextSearchCmd, strict limits} { + deleteWindows + pack [text .t2] + .t2 insert 1.0 "Hello world!\nThis is a test\n" + .t2 search -regexp -strictlimits -backward -- "world" 2.3 1.8 +} {} + +deleteWindows +text .t2 -highlightthickness 0 -bd 0 -relief flat -padx 0 -width 100 +pack .t2 +.t2 insert end "1\t2\t3\t4\t55.5" + +test text-21.1 {TkTextGetTabs procedure} { + list [catch {.t2 configure -tabs "\{{}"} msg] $msg +} {1 {unmatched open brace in list}} +test text-21.2 {TkTextGetTabs procedure} { + list [catch {.t2 configure -tabs xyz} msg] $msg +} {1 {bad screen distance "xyz"}} +test text-21.3 {TkTextGetTabs procedure} { + .t2 configure -tabs {100 200} update idletasks - list [lindex [.t bbox 1.2] 0] [lindex [.t bbox 1.4] 0] -} -cleanup { - destroy .t -} -result {100 200} -test text-23.4 {TkTextGetTabs procedure} -setup { - text .t -highlightthickness 0 -bd 0 -relief flat -padx 0 -width 100 - pack .t -} -body { - .t insert end "1\t2\t3\t4\t55.5" - .t configure -tabs {100 right 200 left 300 center 400 numeric} + list [lindex [.t2 bbox 1.2] 0] [lindex [.t2 bbox 1.4] 0] +} {100 200} +test text-21.4 {TkTextGetTabs procedure} { + .t2 configure -tabs {100 right 200 left 300 center 400 numeric} update idletasks - list [expr [lindex [.t bbox 1.2] 0] + [lindex [.t bbox 1.2] 2]] \ - [lindex [.t bbox 1.4] 0] \ - [expr [lindex [.t bbox 1.6] 0] + [lindex [.t bbox 1.6] 2]/2] \ - [lindex [.t bbox 1.10] 0] -} -cleanup { - destroy .t -} -result {100 200 300 400} -test text-23.5 {TkTextGetTabs procedure} -setup { - text .t -highlightthickness 0 -bd 0 -relief flat -padx 0 -width 100 - pack .t -} -body { - .t insert end "1\t2\t3\t4\t55.5" - .t configure -tabs {105 r 205 l 305 c 405 n} + list [expr [lindex [.t2 bbox 1.2] 0] + [lindex [.t2 bbox 1.2] 2]] \ + [lindex [.t2 bbox 1.4] 0] \ + [expr [lindex [.t2 bbox 1.6] 0] + [lindex [.t2 bbox 1.6] 2]/2] \ + [lindex [.t2 bbox 1.10] 0] +} {100 200 300 400} +test text-21.5 {TkTextGetTabs procedure} { + .t2 configure -tabs {105 r 205 l 305 c 405 n} update idletasks - list [expr [lindex [.t bbox 1.2] 0] + [lindex [.t bbox 1.2] 2]] \ - [lindex [.t bbox 1.4] 0] \ - [expr [lindex [.t bbox 1.6] 0] + [lindex [.t bbox 1.6] 2]/2] \ - [lindex [.t bbox 1.10] 0] -} -cleanup { - destroy .t -} -result {105 205 305 405} -test text-23.6 {TkTextGetTabs procedure} -setup { - text .t -highlightthickness 0 -bd 0 -relief flat -padx 0 -width 100 - pack .t -} -body { - .t insert end "1\t2\t3\t4\t55.5" - .t configure -tabs {100 left 200 lork} -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad tab alignment "lork": must be left, right, center, or numeric} -test text-23.7 {TkTextGetTabs procedure} -setup { - text .t -highlightthickness 0 -bd 0 -relief flat -padx 0 -width 100 - pack .t -} -body { - .t insert end "1\t2\t3\t4\t55.5" - .t configure -tabs {100 !44 200 lork} -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad screen distance "!44"} - - -test text-24.1 {TextDumpCmd procedure, bad args} -body { - pack [text .t] - .t insert 1.0 "One Line" - .t mark set insert 1.0 - .t dump -} -cleanup { - destroy .t -} -returnCodes {error} -result {Usage: .t dump ?-all -image -text -mark -tag -window? ?-command script? index ?index2?} -test text-24.2 {TextDumpCmd procedure, bad args} -body { - pack [text .t] - .t insert 1.0 "One Line" - .t mark set insert 1.0 - .t dump -all -} -cleanup { - destroy .t -} -returnCodes {error} -result {Usage: .t dump ?-all -image -text -mark -tag -window? ?-command script? index ?index2?} -test text-24.3 {TextDumpCmd procedure, bad args} -body { - pack [text .t] - .t insert 1.0 "One Line" - .t mark set insert 1.0 - .t dump -command -} -cleanup { - destroy .t -} -returnCodes {error} -result {Usage: .t dump ?-all -image -text -mark -tag -window? ?-command script? index ?index2?} -test text-24.4 {TextDumpCmd procedure, bad args} -body { - pack [text .t] - .t insert 1.0 "One Line" - .t mark set insert 1.0 - .t dump -bogus -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad option "-bogus": must be -all, -command, -image, -mark, -tag, -text, or -window} -test text-24.5 {TextDumpCmd procedure, bad args} -body { - pack [text .t] - .t insert 1.0 "One Line" - .t mark set insert 1.0 - .t dump bogus -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad text index "bogus"} -test text-24.6 {TextDumpCmd procedure, one index} -body { - pack [text .t] - .t insert 1.0 "One Line" + list [expr [lindex [.t2 bbox 1.2] 0] + [lindex [.t2 bbox 1.2] 2]] \ + [lindex [.t2 bbox 1.4] 0] \ + [expr [lindex [.t2 bbox 1.6] 0] + [lindex [.t2 bbox 1.6] 2]/2] \ + [lindex [.t2 bbox 1.10] 0] +} {105 205 305 405} +test text-21.6 {TkTextGetTabs procedure} { + list [catch {.t2 configure -tabs {100 left 200 lork}} msg] $msg +} {1 {bad tab alignment "lork": must be left, right, center, or numeric}} +test text-21.7 {TkTextGetTabs procedure} { + list [catch {.t2 configure -tabs {100 !44 200 lork}} msg] $msg +} {1 {bad screen distance "!44"}} + +deleteWindows +text .t +pack .t +.t insert 1.0 "One Line" +.t mark set insert 1.0 + +test text-22.1 {TextDumpCmd procedure, bad args} { + list [catch {.t dump} msg] $msg +} {1 {Usage: .t dump ?-all -image -text -mark -tag -window? ?-command script? index ?index2?}} +test text-22.2 {TextDumpCmd procedure, bad args} { + list [catch {.t dump -all} msg] $msg +} {1 {Usage: .t dump ?-all -image -text -mark -tag -window? ?-command script? index ?index2?}} +test text-22.3 {TextDumpCmd procedure, bad args} { + list [catch {.t dump -command} msg] $msg +} {1 {Usage: .t dump ?-all -image -text -mark -tag -window? ?-command script? index ?index2?}} +test text-22.4 {TextDumpCmd procedure, bad args} { + list [catch {.t dump -bogus} msg] $msg +} {1 {bad option "-bogus": must be -all, -command, -image, -mark, -tag, -text, or -window}} +test text-22.5 {TextDumpCmd procedure, bad args} { + list [catch {.t dump bogus} msg] $msg +} {1 {bad text index "bogus"}} +test text-22.6 {TextDumpCmd procedure, one index} { .t dump -text 1.2 -} -cleanup { - destroy .t -} -result {text e 1.2} -test text-24.7 {TextDumpCmd procedure, two indices} -body { - pack [text .t] - .t insert 1.0 "One Line" +} {text e 1.2} +test text-22.7 {TextDumpCmd procedure, two indices} { .t dump -text 1.0 1.end -} -cleanup { - destroy .t -} -result {text {One Line} 1.0} -test text-24.8 {TextDumpCmd procedure, "end" index} -body { - pack [text .t] - .t insert 1.0 "One Line" +} {text {One Line} 1.0} +test text-22.8 {TextDumpCmd procedure, "end" index} { .t dump -text 1.end end -} -cleanup { - destroy .t -} -result {text { +} {text { } 1.8} -test text-24.9 {TextDumpCmd procedure, same indices} -body { - pack [text .t] - .t insert 1.0 "One Line" +test text-22.9 {TextDumpCmd procedure, same indices} { .t dump 1.5 1.5 -} -cleanup { - destroy .t -} -result {} -test text-24.10 {TextDumpCmd procedure, negative range} -body { - pack [text .t] - .t insert 1.0 "One Line" - .t mark set insert 1.0 +} {} +test text-22.10 {TextDumpCmd procedure, negative range} { .t dump 1.5 1.0 -} -cleanup { - destroy .t -} -result {} -test text-24.11 {TextDumpCmd procedure, stop at begin-line} -body { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" +} {} +.t delete 1.0 end +.t insert end "Line One\nLine Two\nLine Three\nLine Four" +.t mark set insert 1.0 +.t mark set current 1.0 +test text-22.11 {TextDumpCmd procedure, stop at begin-line} { .t dump -text 1.0 2.0 -} -cleanup { - destroy .t -} -result {text {Line One +} {text {Line One } 1.0} -test text-24.12 {TextDumpCmd procedure, span multiple lines} -body { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" +test text-22.12 {TextDumpCmd procedure, span multiple lines} { .t dump -text 1.5 3.end -} -cleanup { - destroy .t -} -result {text {One +} {text {One } 1.5 text {Line Two } 2.0 text {Line Three} 3.0} -test text-24.13 {TextDumpCmd procedure, tags only} -body { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - .t tag add x 2.0 2.end - .t tag add y 1.0 end +.t tag add x 2.0 2.end +.t tag add y 1.0 end +.t mark set m 2.4 +.t mark set n 4.0 +.t mark set END end +test text-22.13 {TextDumpCmd procedure, tags only} { .t dump -tag 2.1 2.8 -} -cleanup { - destroy .t -} -result {} -test text-24.14 {TextDumpCmd procedure, tags only} -body { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - .t tag add x 2.0 2.end - .t tag add y 1.0 end +} {} +test text-22.14 {TextDumpCmd procedure, tags only} { .t dump -tag 2.0 2.8 -} -cleanup { - destroy .t -} -result {tagon x 2.0} -test text-24.15 {TextDumpCmd procedure, tags only} -body { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - .t tag add x 2.0 2.end - .t tag add y 1.0 end +} {tagon x 2.0} +test text-22.15 {TextDumpCmd procedure, tags only} { .t dump -tag 1.0 4.end -} -cleanup { - destroy .t -} -result {tagon y 1.0 tagon x 2.0 tagoff x 2.8} -test text-24.16 {TextDumpCmd procedure, tags only} -body { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - .t tag add x 2.0 2.end - .t tag add y 1.0 end +} {tagon y 1.0 tagon x 2.0 tagoff x 2.8} +test text-22.16 {TextDumpCmd procedure, tags only} { .t dump -tag 1.0 end -} -cleanup { - destroy .t -} -result {tagon y 1.0 tagon x 2.0 tagoff x 2.8 tagoff y 5.0} -test text-24.17 {TextDumpCmd procedure, marks only} -body { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - .t mark set insert 1.0 - .t mark set current 1.0 - .t mark set m 2.4 - .t mark set n 4.0 - .t mark set END end +} {tagon y 1.0 tagon x 2.0 tagoff x 2.8 tagoff y 5.0} +.t mark set insert 1.0 +.t mark set current 1.0 +test text-22.17 {TextDumpCmd procedure, marks only} { .t dump -mark 1.1 1.8 -} -cleanup { - destroy .t -} -result {} -test text-24.18 {TextDumpCmd procedure, marks only} -body { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - .t mark set insert 1.0 - .t mark set current 1.0 - .t mark set m 2.4 - .t mark set n 4.0 - .t mark set END end +} {} +test text-22.18 {TextDumpCmd procedure, marks only} { .t dump -mark 2.0 2.8 -} -cleanup { - destroy .t -} -result {mark m 2.4} -test text-24.19 {TextDumpCmd procedure, marks only} -body { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - .t mark set insert 1.0 - .t mark set current 1.0 - .t mark set m 2.4 - .t mark set n 4.0 - .t mark set END end +} {mark m 2.4} +test text-22.19 {TextDumpCmd procedure, marks only} { .t dump -mark 1.1 4.end -} -cleanup { - destroy .t -} -result {mark m 2.4 mark n 4.0} -test text-24.20 {TextDumpCmd procedure, marks only} -body { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - .t mark set insert 1.0 - .t mark set current 1.0 - .t mark set m 2.4 - .t mark set n 4.0 - .t mark set END end +} {mark m 2.4 mark n 4.0} +test text-22.20 {TextDumpCmd procedure, marks only} { .t dump -mark 1.0 end -} -cleanup { - destroy .t -} -result {mark current 1.0 mark insert 1.0 mark m 2.4 mark n 4.0 mark END 5.0} -test text-24.21 {TextDumpCmd procedure, windows only} -setup { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - for {set i 0} {$i < 100} {incr i} {.t insert end "-\n"} - button .hello -text Hello -} -body { - .t window create 3.end -window .hello - .t window create 100.0 -create { } +} {mark current 1.0 mark insert 1.0 mark m 2.4 mark n 4.0 mark END 5.0} +button .hello -text Hello +.t window create 3.end -window .hello +for {set i 0} {$i < 100} {incr i} { + .t insert end "-\n" +} +.t window create 100.0 -create { } +test text-22.21 {TextDumpCmd procedure, windows only} { .t dump -window 1.0 5.0 -} -cleanup { - destroy .t -} -result {window .hello 3.10} -test text-24.22 {TextDumpCmd procedure, windows only} -setup { - pack [text .t] - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - for {set i 0} {$i < 100} {incr i} {.t insert end "-\n"} - button .hello -text Hello -} -body { - .t window create 3.end -window .hello - .t window create 100.0 -create { } +} {window .hello 3.10} +test text-22.22 {TextDumpCmd procedure, windows only} { .t dump -window 5.0 end -} -cleanup { - destroy .t -} -result {window {} 100.0} -test text-24.23 {TextDumpCmd procedure, command script} -setup { +} {window {} 100.0} +.t delete 1.0 end +eval {.t mark unset} [.t mark names] +.t insert end "Line One\nLine Two\nLine Three\nLine Four" +.t mark set insert 1.0 +.t mark set current 1.0 +.t tag add x 2.0 2.end +.t mark set m 2.4 +proc Append {varName key value index} { + upvar #0 $varName x + lappend x $key $index $value +} +test text-22.23 {TextDumpCmd procedure, command script} { set x {} - pack [text .t] - proc Append {varName key value index} { - upvar #0 $varName x - lappend x $key $index $value - } -} -body { - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - .t mark set insert 1.0 - .t mark set current 1.0 - .t tag add x 2.0 2.end - .t mark set m 2.4 .t dump -command {Append x} -all 1.0 end - return $x -} -cleanup { - destroy .t - rename Append {} -} -result {mark 1.0 current mark 1.0 insert text 1.0 {Line One + set x +} {mark 1.0 current mark 1.0 insert text 1.0 {Line One } tagon 2.0 x text 2.0 Line mark 2.4 m text 2.4 { Two} tagoff 2.8 x text 2.8 { } text 3.0 {Line Three } text 4.0 {Line Four }} -test text-24.24 {TextDumpCmd procedure, command script} -setup { +test text-22.24 {TextDumpCmd procedure, command script} { set x {} - pack [text .t] - proc Append {varName key value index} { - upvar #0 $varName x - lappend x $key $index $value - } -} -body { - .t insert end "Line One\nLine Two\nLine Three\nLine Four" - .t mark set insert 1.0 - .t mark set current 1.0 - .t mark set m 2.4 .t dump -mark -command {Append x} 1.0 end - return $x -} -cleanup { - destroy .t - rename Append {} -} -result {mark 1.0 current mark 1.0 insert mark 2.4 m} -test text-24.25 {TextDumpCmd procedure, unicode characters} -body { + set x +} {mark 1.0 current mark 1.0 insert mark 2.4 m} +catch {unset x} +test text-22.25 {TextDumpCmd procedure, unicode characters} { + catch {destroy .t} text .t + .t delete 1.0 end .t insert 1.0 \xb1\xb1\xb1 .t dump -all 1.0 2.0 -} -cleanup { - destroy .t -} -result "text \xb1\xb1\xb1 1.0 mark insert 1.3 mark current 1.3 text {\n} 1.3" -test text-24.26 {TextDumpCmd procedure, unicode characters} -body { +} "text \xb1\xb1\xb1 1.0 mark insert 1.3 mark current 1.3 text {\n} 1.3" +test text-22.26 {TextDumpCmd procedure, unicode characters} { + catch {destroy .t} text .t .t delete 1.0 end .t insert 1.0 abc\xb1\xb1\xb1 .t dump -all 1.0 2.0 -} -cleanup { +} "text abc\xb1\xb1\xb1 1.0 mark insert 1.6 mark current 1.6 text {\n} 1.6" +test text-22.27 {TextDumpCmd procedure, peer present} -setup { destroy .t -} -result "text abc\xb1\xb1\xb1 1.0 mark insert 1.6 mark current 1.6 text {\n} 1.6" -test text-24.27 {TextDumpCmd procedure, peer present} -body { +} -body { text .t .t peer create .t.t .t dump -all 1.0 end @@ -6199,18 +3034,21 @@ test text-24.27 {TextDumpCmd procedure, peer present} -body { destroy .t } -result "mark insert 1.0 mark current 1.0 text {\n} 1.0" -test text-25.1 {text widget vs hidden commands} -body { +set l [interp hidden] +deleteWindows + +test text-23.1 {text widget vs hidden commands} { + catch {destroy .t} text .t - set y [list {} [interp hidden]] interp hide {} .t destroy .t - set x [list [winfo children .] [interp hidden]] - expr {$x eq $y} -} -result {1} - + list [winfo children .] [interp hidden] +} [list {} $l] -test text-26.1 {bug fix - 1642} -body { - pack [text .t] +test text-24.1 {bug fix - 1642} { + catch {destroy .t} + text .t + pack .t .t insert end "line 1\n" .t insert end "line 2\n" .t insert end "line 3\n" @@ -6218,24 +3056,16 @@ test text-26.1 {bug fix - 1642} -body { .t insert end "line 5\n" tk::TextSetCursor .t 3.0 .t search -backward -regexp "\$" insert 1.0 -} -cleanup { - destroy .t -} -result {2.6} - - -test text-27.1 {TextEditCmd procedure, argument parsing} -body { - pack [text .t] - .t edit -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t edit option ?arg ...?"} -test text-27.2 {TextEditCmd procedure, argument parsing} -body { - pack [text .t] - .t edit gorp -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad edit option "gorp": must be canundo, canredo, modified, redo, reset, separator, or undo} -test text-27.3 {TextEditUndo procedure, undoing changes} -body { +} {2.6} + +test text-25.1 {TextEditCmd procedure, argument parsing} { + list [catch {.t edit} msg] $msg +} {1 {wrong # args: should be ".t edit option ?arg arg ...?"}} +test text-25.2 {TextEditCmd procedure, argument parsing} { + list [catch {.t edit gorp} msg] $msg +} {1 {bad edit option "gorp": must be modified, redo, reset, separator, or undo}} +test text-25.3 {TextEditUndo procedure, undoing changes} { + catch {destroy .t} text .t -undo 1 pack .t .t insert end "line 1\n" @@ -6243,10 +3073,9 @@ test text-27.3 {TextEditUndo procedure, undoing changes} -body { .t insert end "should be gone after undo\n" .t edit undo .t get 1.0 end -} -cleanup { - destroy .t -} -result "line\n\n" -test text-27.4 {TextEditRedo procedure, redoing changes} -body { +} "line\n\n" +test text-25.4 {TextEditRedo procedure, redoing changes} { + catch {destroy .t} text .t -undo 1 pack .t .t insert end "line 1\n" @@ -6255,10 +3084,9 @@ test text-27.4 {TextEditRedo procedure, redoing changes} -body { .t edit undo .t edit redo .t get 1.0 end -} -cleanup { - destroy .t -} -result "line\nshould be back after redo\n\n" -test text-27.5 {TextEditUndo procedure, resetting stack} -body { +} "line\nshould be back after redo\n\n" +test text-25.5 {TextEditUndo procedure, resetting stack} { + catch {destroy .t} text .t -undo 1 pack .t .t insert end "line 1\n" @@ -6266,11 +3094,10 @@ test text-27.5 {TextEditUndo procedure, resetting stack} -body { .t insert end "should be back after redo\n" .t edit reset catch {.t edit undo} msg - return $msg -} -cleanup { - destroy .t -} -result "nothing to undo" -test text-27.6 {TextEditCmd procedure, insert separator} -body { + set msg +} "nothing to undo" +test text-25.6 {TextEditCmd procedure, insert separator} { + catch {destroy .t} text .t -undo 1 pack .t .t insert end "line 1\n" @@ -6278,10 +3105,9 @@ test text-27.6 {TextEditCmd procedure, insert separator} -body { .t insert end "line 2\n" .t edit undo .t get 1.0 end -} -cleanup { - destroy .t -} -result "line 1\n\n" -test text-27.7 {-autoseparators configuration option} -body { +} "line 1\n\n" +test text-25.7 {-autoseparators configuration option} { + catch {destroy .t} text .t -undo 1 -autoseparators 0 pack .t .t insert end "line 1\n" @@ -6289,115 +3115,87 @@ test text-27.7 {-autoseparators configuration option} -body { .t insert end "line 2\n" .t edit undo .t get 1.0 end -} -cleanup { - destroy .t -} -result "\n" -test text-27.8 {TextEditCmd procedure, modified flag} -body { +} "\n" +test text-25.8 {TextEditCmd procedure, modified flag} { + catch {destroy .t} text .t pack .t .t insert end "line 1\n" .t edit modified -} -cleanup { - destroy .t -} -result {1} -test text-27.9 {TextEditCmd procedure, reset modified flag} -body { +} {1} +test text-25.9 {TextEditCmd procedure, reset modified flag} { + catch {destroy .t} text .t pack .t .t insert end "line 1\n" .t edit modified 0 .t edit modified -} -cleanup { - destroy .t -} -result {0} -test text-27.10 {TextEditCmd procedure, set modified flag} -body { +} {0} +test text-25.10 {TextEditCmd procedure, set modified flag} { + catch {destroy .t} text .t pack .t .t edit modified 1 .t edit modified -} -cleanup { - destroy .t -} -result {1} -test text-27.11 {TextEditCmd procedure, set modified flag repeat} -setup { +} {1} +test text-25.10.1 {TextEditCmd procedure, set modified flag repeat} { + catch {destroy .t} text .t pack .t set ::retval {} -} -body { bind .t <<Modified>> "lappend ::retval modified" -# Shouldn't require [update idle] to trigger event [Bug 1809538] + # Shouldn't require [update idle] to trigger event [Bug 1809538] lappend ::retval [.t edit modified] .t edit modified 1 - update + update idletasks lappend ::retval [.t edit modified] .t edit modified 1 ; # binding should only fire once [Bug 1799782] update idletasks lappend ::retval [.t edit modified] -} -cleanup { - destroy .t -} -result {0 modified 1 1} -test text-27.12 {<<Modified>> virtual event} -body { +} {0 modified 1 1} +test text-25.11 {<<Modified>> virtual event} { set ::retval unmodified + catch {destroy .t} text .t -undo 1 pack .t bind .t <<Modified>> "set ::retval modified" update idletasks .t insert end "nothing special\n" - update - return $::retval -} -cleanup { - destroy .t -} -result {modified} -test text-27.13 {<<Modified>> virtual event - insert before Modified} -body { + set ::retval +} {modified} +test text-25.11.1 {<<Modified>> virtual event - insert before Modified} { set ::retval {} + destroy .t pack [text .t -undo 1] bind .t <<Modified>> { set ::retval [.t get 1.0 end-1c] } update idletasks .t insert end "nothing special" - update - return $::retval -} -cleanup { - destroy .t -} -result {nothing special} -test text-27.14 {<<Modified>> virtual event - delete before Modified} -body { -# Bug 1737288, make sure we delete chars before triggering <<Modified>> + set ::retval +} {nothing special} +test text-25.11.2 {<<Modified>> virtual event - delete before Modified} { + # Bug 1737288, make sure we delete chars before triggering <<Modified>> set ::retval {} + destroy .t pack [text .t -undo 1] bind .t <<Modified>> { set ::retval [.t get 1.0 end-1c] } .t insert end "nothing special" .t edit modified 0 .t delete 1.0 1.2 - update - set ::retval -} -cleanup { - destroy .t -} -result {thing special} -test text-27.14a {<<Modified>> virtual event - propagation to peers} -body { -# Bug [fd3a4dc111], <<Modified>> event is not always sent to peers - set ::retval 0 - text .t -undo 1 - .t peer create .tt - pack .t .tt - bind .t <<Modified>> {incr ::retval} - bind .tt <<Modified>> {incr ::retval} - .t insert end "This increments ::retval once for each peer, i.e. twice." - .t edit modified 0 ; # shall increment twice as well, not just once - update set ::retval -} -cleanup { - destroy .t .tt -} -result {4} -test text-27.15 {<<Selection>> virtual event} -body { +} {thing special} +test text-25.12 {<<Selection>> virtual event} { set ::retval no_selection - pack [text .t -undo 1] + catch {destroy .t} + text .t -undo 1 + pack .t bind .t <<Selection>> "set ::retval selection_changed" update idletasks .t insert end "nothing special\n" .t tag add sel 1.0 1.1 - update set ::retval -} -cleanup { - destroy .t -} -result {selection_changed} -test text-27.16 {-maxundo configuration option} -body { +} {selection_changed} +test text-25.13 {-maxundo configuration option} { + catch {destroy .t} text .t -undo 1 -autoseparators 1 -maxundo 2 pack .t .t insert end "line 1\n" @@ -6407,50 +3205,17 @@ test text-27.16 {-maxundo configuration option} -body { catch {.t edit undo} catch {.t edit undo} .t get 1.0 end -} -cleanup { - destroy .t -} -result "line 1\n\n" -test text-27.16a {undo configuration options with peers} -body { - text .t -undo 1 -autoseparators 0 -maxundo 100 - .t peer create .tt - set res [.t cget -undo] - lappend res [.tt cget -undo] - lappend res [.t cget -autoseparators] - lappend res [.tt cget -autoseparators] - lappend res [.t cget -maxundo] - lappend res [.tt cget -maxundo] - .t insert end "The undo stack is common between peers" - lappend res [.t edit canundo] - lappend res [.tt edit canundo] -} -cleanup { - destroy .t .tt -} -result {1 1 0 0 100 100 1 1} -test text-27.16b {undo configuration options with peers, defaults} -body { - text .t - .t peer create .tt - set res [.t cget -undo] - lappend res [.tt cget -undo] - lappend res [.t cget -autoseparators] - lappend res [.tt cget -autoseparators] - lappend res [.t cget -maxundo] - lappend res [.tt cget -maxundo] - .t insert end "The undo stack is common between peers" - lappend res [.t edit canundo] - lappend res [.tt edit canundo] -} -cleanup { - destroy .t .tt -} -result {0 0 1 1 0 0 0 0} -test text-27.17 {bug fix 1536735 - undo with empty text} -body { +} "line 1\n\n" +test text-25.15 {bug fix 1536735 - undo with empty text} { + catch {destroy .t} text .t -undo 1 set r [.t edit modified] .t delete 1.0 lappend r [.t edit modified] lappend r [catch {.t edit undo}] lappend r [.t edit modified] -} -cleanup { - destroy .t -} -result {0 0 1 0} -test text-27.18 {patch 1469210 - inserting after undo} -setup { +} {0 0 1 0} +test text-25.18 {patch 1469210 - inserting after undo} -setup { destroy .t } -body { text .t -undo 1 @@ -6462,7 +3227,7 @@ test text-27.18 {patch 1469210 - inserting after undo} -setup { } -cleanup { destroy .t } -result 1 -test text-27.19 {patch 1669632 (i) - undo after <Control-1>} -setup { +test text-25.19 {patch 1669632 (i) - undo after <Control-1>} -setup { destroy .t } -body { text .t -undo 1 @@ -6476,8 +3241,8 @@ test text-27.19 {patch 1669632 (i) - undo after <Control-1>} -setup { } -cleanup { destroy .t } -result WORLD -test text-27.20 {patch 1669632 (iv) - undo after <<SelectNone>>} -setup { - destroy .top .top.t +test text-25.20 {patch 1669632 (iv) - undo after <Control-backslash>} -setup { + destroy .t } -body { toplevel .top pack [text .top.t -undo 1] @@ -6488,14 +3253,14 @@ test text-27.20 {patch 1669632 (iv) - undo after <<SelectNone>>} -setup { .top.t tag add sel 1.10 1.12 update focus -force .top.t - event generate .top.t <<SelectNone>> + event generate .top.t <Control-backslash> .top.t insert insert " WORLD " .top.t edit undo .top.t get 1.5 1.10 } -cleanup { destroy .top.t .top } -result HELLO -test text-27.21 {patch 1669632 (vii) - <<Undo>> shall not remove separators} -setup { +test text-25.21 {patch 1669632 (vii) - <<Undo>> shall not remove separators} -setup { destroy .t } -body { text .t -undo 1 @@ -6511,7 +3276,7 @@ test text-27.21 {patch 1669632 (vii) - <<Undo>> shall not remove separators} -se } -cleanup { destroy .t } -result "This WORLD is an example text" -test text-27.22 {patch 1669632 (v) - <<Clear>> is atomic} -setup { +test text-25.22 {patch 1669632 (v) - <<Clear>> is atomic} -setup { destroy .t } -body { toplevel .top @@ -6523,7 +3288,7 @@ test text-27.22 {patch 1669632 (v) - <<Clear>> is atomic} -setup { update focus -force .top.t event generate .top.t <Delete> - event generate .top.t <<SelectNextChar>> + event generate .top.t <Shift-Right> event generate .top.t <<Clear>> event generate .top.t <Delete> event generate .top.t <<Undo>> @@ -6531,7 +3296,7 @@ test text-27.22 {patch 1669632 (v) - <<Clear>> is atomic} -setup { } -cleanup { destroy .top.t .top } -result "This A an example text" - test text-27.23 {patch 1669632 (v) - <<Cut>> is atomic} -setup { + test text-25.23 {patch 1669632 (v) - <<Cut>> is atomic} -setup { destroy .t } -body { toplevel .top @@ -6543,7 +3308,7 @@ test text-27.22 {patch 1669632 (v) - <<Clear>> is atomic} -setup { update focus -force .top.t event generate .top.t <Delete> - event generate .top.t <<SelectNextChar>> + event generate .top.t <Shift-Right> event generate .top.t <<Cut>> event generate .top.t <Delete> event generate .top.t <<Undo>> @@ -6551,345 +3316,247 @@ test text-27.22 {patch 1669632 (v) - <<Clear>> is atomic} -setup { } -cleanup { destroy .top.t .top } -result "This A an example text" -test text-27.24 {TextEditCmd procedure, canundo and canredo} -setup { - destroy .t - set res {} -} -body { - text .t -undo false -autoseparators false - lappend res [.t edit canundo] [.t edit canredo] - .t configure -undo true - lappend res [.t edit canundo] [.t edit canredo] - .t insert end "DO\n" - .t edit separator - .t insert end "IT\n" - .t insert end "YOURSELF\n" - .t edit separator - lappend res [.t edit canundo] [.t edit canredo] - .t edit undo - lappend res [.t edit canundo] [.t edit canredo] - .t configure -undo false - lappend res [.t edit canundo] [.t edit canredo] - .t configure -undo true - lappend res [.t edit canundo] [.t edit canredo] - .t edit redo - lappend res [.t edit canundo] [.t edit canredo] -} -cleanup { - destroy .t -} -result {0 0 0 0 1 0 1 1 0 0 1 1 1 0} -test text-27.25 {<<UndoStack>> virtual event} -setup { - destroy .t - set res {} - set nbUS 0 -} -body { - text .t -undo false -autoseparators false - bind .t <<UndoStack>> {incr nbUS} - update ; lappend res $nbUS - .t configure -undo true - update ; lappend res $nbUS - .t insert end "DO\n" - .t edit separator - .t insert end "IT\n" - .t insert end "YOURSELF\n" - .t edit separator - .t insert end "MAN\n" - .t edit separator - update ; lappend res $nbUS - .t edit undo - update ; lappend res $nbUS - .t edit redo - update ; lappend res $nbUS - .t edit undo - update ; lappend res $nbUS - .t edit undo - update ; lappend res $nbUS - .t edit undo - update ; lappend res $nbUS - .t edit redo - update ; lappend res $nbUS - .t edit redo - update ; lappend res $nbUS - .t edit redo - update ; lappend res $nbUS - .t edit undo - update ; lappend res $nbUS - .t edit undo - update ; lappend res $nbUS - .t edit reset - update ; lappend res $nbUS -} -cleanup { - destroy .t -} -result {0 0 1 2 3 4 4 5 6 6 7 8 8 9} - -test text-28.1 {bug fix - 624372, ControlUtfProc long lines} -body { +test text-26.1 {bug fix - 624372, ControlUtfProc long lines} { + destroy .t pack [text .t -wrap none] .t insert end [string repeat "\1" 500] -} -cleanup { - destroy .t -} -result {} +} {} - -test text-29.1 {tabs - must be positive and must be increasing} -body { +test text-27.1 {tabs - must be positive and must be increasing} { + destroy .t pack [text .t -wrap none] - .t configure -tabs {0} -} -cleanup { + list [catch {.t configure -tabs {0}} msg] $msg +} {1 {tab stop "0" is not at a positive distance}} +test text-27.2 {tabs - must be positive and must be increasing} { destroy .t -} -returnCodes {error} -result {tab stop "0" is not at a positive distance} -test text-29.2 {tabs - must be positive and must be increasing} -body { pack [text .t -wrap none] - .t configure -tabs {-5} -} -cleanup { + list [catch {.t configure -tabs {-5}} msg] $msg +} {1 {tab stop "-5" is not at a positive distance}} +test text-27.3 {tabs - must be positive and must be increasing} {knownBug} { + # This bug will be fixed in Tk 9.0, when we can allow a minor + # incompatibility with Tk 8.x destroy .t -} -returnCodes {error} -result {tab stop "-5" is not at a positive distance} -test text-29.3 {tabs - must be positive and must be increasing} -constraints { - knownBug -} -body { -# This bug will be fixed in Tk 9.0, when we can allow a minor -# incompatibility with Tk 8.x pack [text .t -wrap none] - .t configure -tabs {10c 5c} -} -cleanup { + list [catch {.t configure -tabs {10c 5c}} msg] $msg +} {1 {tabs must be monotonically increasing, but "5c" is smaller than or equal to the previous tab}} +test text-27.4 {tabs - must be positive and must be increasing} { destroy .t -} -returnCodes {error} -result {tabs must be monotonically increasing, but "5c" is smaller than or equal to the previous tab} -test text-29.4 {tabs - must be positive and must be increasing} -body { pack [text .t -wrap none] .t insert end "a\tb\tc\td\te" catch {.t configure -tabs {10c 5c}} update ; update ; update -# This test must simply not go into an infinite loop to succeed - set result 1 -} -cleanup { - destroy .t -} -result {1} - - -test text-30.1 {repeated insert and scroll} -body { - pack [text .t] - for {set i 0} {$i < 30} {incr i} { - .t insert end "blabla\n" - eval .t yview moveto 1 - } -# This test must simply not crash to succeed - set result 1 -} -cleanup { - destroy .t -} -result {1} -test text-30.2 {repeated insert and scroll} -body { - pack [text .t] - for {set i 0} {$i < 30} {incr i} { - .t insert end "blabla\n" - eval .t yview scroll 1 pages - } -# This test must simply not crash to succeed + # This test must simply not go into an infinite loop to succeed set result 1 -} -cleanup { - destroy .t -} -result {1} -test text-30.3 {repeated insert and scroll} -body { - pack [text .t] - for {set i 0} {$i < 30} {incr i} { - .t insert end "blabla\n" - eval .t yview scroll 100 pixels +} {1} + +test text-28.0 {repeated insert and scroll} { + foreach subcmd { + {moveto 1} + {scroll 1 pages} + {scroll 100 pixels} + {scroll 10 units} + } { + destroy .t + pack [text .t] + for {set i 0} {$i < 30} {incr i} { + .t insert end "blabla\n" + eval .t yview $subcmd + } } -# This test must simply not crash to succeed + # This test must simply not crash to succeed set result 1 -} -cleanup { - destroy .t -} -result {1} -test text-30.4 {repeated insert and scroll} -body { - pack [text .t] - for {set i 0} {$i < 30} {incr i} { - .t insert end "blabla\n" - eval .t yview scroll 10 units - } -# This test must simply not crash to succeed - set result 1 -} -cleanup { - destroy .t -} -result {1} +} {1} - -test text-31.1 {peer widgets} -body { - toplevel .top - pack [text .t] - pack [.t peer create .top.t] - destroy .t .top -} -result {} -test text-31.2 {peer widgets} -body { - toplevel .top1 - toplevel .top2 +test text-29.0 {peer widgets} { + destroy .t .tt + toplevel .tt pack [text .t] - pack [.t peer create .top1.t] - pack [.t peer create .top2.t] + pack [.t peer create .tt.t] + destroy .t .tt +} {} +test text-29.1 {peer widgets} { + destroy .t .t1 .t2 + toplevel .t1 + toplevel .t2 + pack [text .t] + pack [.t peer create .t1.t] + pack [.t peer create .t2.t] .t insert end "abcd\nabcd" update - destroy .top1 + destroy .t1 update .t insert end "abcd\nabcd" update - destroy .t .top2 + destroy .t .t2 update -} -result {} -test text-31.3 {peer widgets} -body { - toplevel .top1 - toplevel .top2 +} {} +test text-29.2 {peer widgets} { + destroy .t .t1 .t2 + toplevel .t1 + toplevel .t2 pack [text .t] - pack [.t peer create .top1.t] - pack [.t peer create .top2.t] + pack [.t peer create .t1.t] + pack [.t peer create .t2.t] .t insert end "abcd\nabcd" update destroy .t update - .top2.t insert end "abcd\nabcd" + .t2.t insert end "abcd\nabcd" update - destroy .t .top2 + destroy .t .t2 update -} -result {} -test text-31.4 {peer widgets} -body { - toplevel .top +} {} +test text-29.3 {peer widgets} { + destroy .t .tt + toplevel .tt pack [text .t] for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } - pack [.t peer create .top.t -start 5 -end 11] + pack [.t peer create .tt.t -start 5 -end 11] update - destroy .t .top -} -result {} -test text-31.5 {peer widgets} -body { - toplevel .top + destroy .t .tt +} {} +test text-29.4 {peer widgets} { + destroy .t .tt + toplevel .tt pack [text .t] for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } - pack [.t peer create .top.t -start 5 -end 11] - pack [.top.t peer create .top.t2] - set res [list [.top.t index end] [.top.t2 index end]] + pack [.t peer create .tt.t -start 5 -end 11] + pack [.tt.t peer create .tt.t2] + set res [list [.tt.t index end] [.tt.t2 index end]] update - return $res -} -cleanup { - destroy .t .top -} -result {7.0 7.0} -test text-31.6 {peer widgets} -body { - toplevel .top + destroy .t .tt + set res +} {7.0 7.0} +test text-29.4.1 {peer widgets} { + destroy .t .tt + toplevel .tt pack [text .t] for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } - pack [.t peer create .top.t -start 5 -end 11] - pack [.top.t peer create .top.t2 -start {} -end {}] - set res [list [.top.t index end] [.top.t2 index end]] + pack [.t peer create .tt.t -start 5 -end 11] + pack [.tt.t peer create .tt.t2 -start {} -end {}] + set res [list [.tt.t index end] [.tt.t2 index end]] update - return $res -} -cleanup { - destroy .t .top -} -result {7.0 21.0} -test text-31.7 {peer widgets} -body { - toplevel .top + destroy .t .tt + set res +} {7.0 21.0} +test text-29.5 {peer widgets} { + destroy .t .tt + toplevel .tt pack [text .t] for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } - pack [.t peer create .top.t -start 5 -end 11] + pack [.t peer create .tt.t -start 5 -end 11] update ; update - set p1 [.top.t count -update -ypixels 1.0 end] + set p1 [.tt.t count -update -ypixels 1.0 end] set p2 [.t count -update -ypixels 5.0 11.0] - expr {$p1 eq $p2} -} -cleanup { - destroy .t .top -} -result {1} -test text-31.8 {peer widgets} -body { - toplevel .top + if {$p1 == $p2} { + set res "ok" + } else { + set res "$p1 and $p2 not equal" + } + destroy .t .tt + set res +} {ok} +test text-29.6 {peer widgets} { + destroy .t .tt + toplevel .tt pack [text .t] for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } - pack [.t peer create .top.t -start 5 -end 11] + pack [.t peer create .tt.t -start 5 -end 11] update ; update .t delete 3.0 6.0 - .top.t index end -} -cleanup { - destroy .t .top -} -result {6.0} -test text-31.9 {peer widgets} -body { - toplevel .top + set res [.tt.t index end] + destroy .t .tt + set res +} {6.0} +test text-29.7 {peer widgets} { + destroy .t .tt + toplevel .tt pack [text .t] for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } - pack [.t peer create .top.t -start 5 -end 11] + pack [.t peer create .tt.t -start 5 -end 11] update ; update .t delete 8.0 12.0 - .top.t index end -} -cleanup { - destroy .t .top -} -result {4.0} -test text-31.10 {peer widgets} -body { - toplevel .top + set res [.tt.t index end] + destroy .t .tt + set res +} {4.0} +test text-29.8 {peer widgets} { + destroy .t .tt + toplevel .tt pack [text .t] - for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + for {set i 1} {$i < 20} {incr i} { + .t insert end "Line $i\n" } - pack [.t peer create .top.t -start 5 -end 11] + pack [.t peer create .tt.t -start 5 -end 11] update ; update .t delete 3.0 13.0 - .top.t index end -} -cleanup { - destroy .t .top -} -result {1.0} -test text-31.11 {peer widgets} -setup { + set res [.tt.t index end] + destroy .t .tt + set res +} {1.0} +test text-29.9 {peer widgets} { + destroy .t pack [text .t] - set res {} -} -body { for {set i 1} {$i < 100} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } .t tag add sel 1.0 end-1c + set res {} lappend res [.t tag ranges sel] .t configure -start 10 -end 20 lappend res [.t tag ranges sel] - return $res -} -cleanup { destroy .t -} -result {{1.0 100.0} {1.0 11.0}} -test text-31.12 {peer widgets} -setup { + set res +} {{1.0 100.0} {1.0 11.0}} +test text-29.10 {peer widgets} { + destroy .t pack [text .t] - set res {} -} -body { for {set i 1} {$i < 100} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } .t tag add sel 1.0 end-1c + set res {} lappend res [.t tag ranges sel] .t configure -start 11 lappend res [.t tag ranges sel] - return $res -} -cleanup { destroy .t -} -result {{1.0 100.0} {1.0 90.0}} -test text-31.13 {peer widgets} -setup { + set res +} {{1.0 100.0} {1.0 90.0}} +test text-29.11 {peer widgets} { + destroy .t pack [text .t] - set res {} -} -body { for {set i 1} {$i < 100} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } .t tag add sel 1.0 end-1c + set res {} lappend res [.t tag ranges sel] .t configure -end 90 lappend res [.t tag ranges sel] destroy .t - return $res -} -cleanup { + set res +} {{1.0 100.0} {1.0 90.0}} +test text-29.12 {peer widgets} { destroy .t -} -result {{1.0 100.0} {1.0 90.0}} -test text-31.14 {peer widgets} -setup { pack [text .t] - set res {} -} -body { for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } .t tag add sel 1.0 3.0 5.0 7.0 9.0 11.0 13.0 15.0 17.0 19.0 + set res {} lappend res [.t tag prevrange sel 1.0] .t configure -start 6 -end 12 lappend res [.t tag ranges sel] @@ -6899,18 +3566,17 @@ test text-31.14 {peer widgets} -setup { lappend res "prev" [.t tag prevrange sel 1.0] \ [.t tag prevrange sel 2.0] [.t tag prevrange sel 3.0] \ [.t tag prevrange sel 4.0] - return $res -} -cleanup { destroy .t -} -result {{} {1.0 2.0 4.0 6.0} next {4.0 6.0} {} {} {} prev {} {1.0 2.0} {1.0 2.0} {1.0 2.0}} -test text-31.15 {peer widgets} -setup { + set res +} {{} {1.0 2.0 4.0 6.0} next {4.0 6.0} {} {} {} prev {} {1.0 2.0} {1.0 2.0} {1.0 2.0}} +test text-29.13 {peer widgets} { + destroy .t pack [text .t] - set res {} -} -body { for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } .t tag add sel 1.0 3.0 9.0 11.0 13.0 15.0 17.0 19.0 + set res {} .t configure -start 6 -end 12 lappend res [.t tag ranges sel] lappend res "next" [.t tag nextrange sel 4.0] \ @@ -6919,18 +3585,17 @@ test text-31.15 {peer widgets} -setup { lappend res "prev" [.t tag prevrange sel 1.0] \ [.t tag prevrange sel 2.0] [.t tag prevrange sel 3.0] \ [.t tag prevrange sel 4.0] - return $res -} -cleanup { destroy .t -} -result {{4.0 6.0} next {4.0 6.0} {} {} {} prev {} {} {} {}} -test text-31.16 {peer widgets} -setup { + set res +} {{4.0 6.0} next {4.0 6.0} {} {} {} prev {} {} {} {}} +test text-29.14 {peer widgets} { + destroy .t pack [text .t] - set res {} -} -body { for {set i 1} {$i < 20} {incr i} { .t insert end "Line $i\n" } .t tag add sel 1.0 7.0 9.0 11.0 13.0 15.0 17.0 19.0 + set res {} .t configure -start 6 -end 12 lappend res [.t tag ranges sel] lappend res "next" [.t tag nextrange sel 4.0] \ @@ -6939,17 +3604,16 @@ test text-31.16 {peer widgets} -setup { lappend res "prev" [.t tag prevrange sel 1.0] \ [.t tag prevrange sel 2.0] [.t tag prevrange sel 3.0] \ [.t tag prevrange sel 4.0] - return $res -} -cleanup { destroy .t -} -result {{1.0 2.0 4.0 6.0} next {4.0 6.0} {} {} {} prev {} {1.0 2.0} {1.0 2.0} {1.0 2.0}} -test text-31.17 {peer widgets} -setup { + set res +} {{1.0 2.0 4.0 6.0} next {4.0 6.0} {} {} {} prev {} {1.0 2.0} {1.0 2.0} {1.0 2.0}} +test text-29.15 {peer widgets} { + destroy .t pack [text .t] - set res {} -} -body { for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } + set res {} .t tag add sel 1.0 11.0 lappend res [.t tag ranges sel] lappend res [catch {.t configure -start 15 -end 10}] @@ -6958,61 +3622,58 @@ test text-31.17 {peer widgets} -setup { lappend res [.t tag ranges sel] .t configure -start {} -end {} lappend res [.t tag ranges sel] - return $res -} -cleanup { destroy .t -} -result {{1.0 11.0} 1 {1.0 11.0} {1.0 6.0} {1.0 11.0}} -test text-31.18 {peer widgets} -setup { + set res +} {{1.0 11.0} 1 {1.0 11.0} {1.0 6.0} {1.0 11.0}} +test text-29.16 {peer widgets} { + destroy .t pack [text .t] - set res {} -} -body { for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } + set res {} .t tag add sel 1.0 11.0 lappend res [.t index sel.first] lappend res [.t index sel.last] - return $res -} -cleanup { destroy .t -} -result {1.0 11.0} -test text-31.19 {peer widgets} -body { + set res +} {1.0 11.0} +test text-29.17 {peer widgets} { + destroy .t pack [text .t] for {set i 1} {$i < 20} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } + set res {} .t tag delete sel - .t index sel.first -} -cleanup { + set res [list [catch {.t index sel.first} msg] $msg] destroy .t -} -returnCodes {error} -result {text doesn't contain any characters tagged with "sel"} - + set res +} {1 {text doesn't contain any characters tagged with "sel"}} -test text-32.1 {line heights on creation} -setup { - text .t - proc makeText {} { - set w .g - set font "Times 11" - destroy .g - toplevel .g - frame $w.f -highlightthickness 2 -borderwidth 2 -relief sunken - set t $w.f.text - text $t -yscrollcommand "$w.scroll set" -setgrid true -font $font \ - -width 70 -height 35 -wrap word -highlightthickness 0 \ - -borderwidth 0 - pack $t -expand yes -fill both - scrollbar $w.scroll -command "$t yview" - pack $w.scroll -side right -fill y - pack $w.f -expand yes -fill both - $t tag configure center -justify center -spacing1 5m -spacing3 5m - $t tag configure buttons -lmargin1 1c -lmargin2 1c -rmargin 1c \ - -spacing1 3m -spacing2 0 -spacing3 0 - for {set i 0} {$i < 40} {incr i} { - $t insert end "${i}word " - } - return $t +proc makeText {} { + set w .g + set font "Times 11" + destroy .g + toplevel .g + frame $w.f -highlightthickness 2 -borderwidth 2 -relief sunken + set t $w.f.text + text $t -yscrollcommand "$w.scroll set" -setgrid true -font $font -width 70 \ + -height 35 -wrap word -highlightthickness 0 -borderwidth 0 + pack $t -expand yes -fill both + scrollbar $w.scroll -command "$t yview" + pack $w.scroll -side right -fill y + pack $w.f -expand yes -fill both + $t tag configure center -justify center -spacing1 5m -spacing3 5m + $t tag configure buttons -lmargin1 1c -lmargin2 1c -rmargin 1c \ + -spacing1 3m -spacing2 0 -spacing3 0 + for {set i 0} {$i < 40} {incr i} { + $t insert end "${i}word " } -} -body { + return $t +} + +test text-30.1 {line heights on creation} { set w [makeText] update ; after 1000 ; update set before [$w count -ypixels 1.0 2.0] @@ -7020,88 +3681,63 @@ test text-32.1 {line heights on creation} -setup { update set after [$w count -ypixels 1.0 2.0] destroy .g - expr {$before eq $after} -} -cleanup { - destroy .t -} -result {1} - - -test text-33.1 {TextWidgetCmd procedure, "peer" option} -setup { - text .t -} -body { - .t peer foo 1 -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad peer option "foo": must be create or names} -test text-33.2 {TextWidgetCmd procedure, "peer" option} -setup { - text .t -} -body { - .t peer names foo -} -cleanup { - destroy .t -} -returnCodes {error} -result {wrong # args: should be ".t peer names"} -test text-33.3 {TextWidgetCmd procedure, "peer" option} -setup { - text .t -} -body { - .t pee names -} -cleanup { - destroy .t -} -returnCodes {ok} -result {} -test text-33.4 {TextWidgetCmd procedure, "peer" option} -setup { - text .t -} -body { + if {$before != $after} { + set res "Count changed: $before $after" + } else { + set res "ok" + } +} {ok} + +destroy .t +text .t +test text-31.1 {TextWidgetCmd procedure, "peer" option} { + list [catch {.t peer foo 1} msg] $msg +} {1 {bad peer option "foo": must be create or names}} +test text-31.2 {TextWidgetCmd procedure, "peer" option} { + list [catch {.t peer names foo} msg] $msg +} {1 {wrong # args: should be ".t peer names"}} +test text-31.3 {TextWidgetCmd procedure, "peer" option} { + list [catch {.t p names} msg] $msg +} {0 {}} +test text-31.4 {TextWidgetCmd procedure, "peer" option} { .t peer names -} -cleanup { - destroy .t -} -result {} -test text-33.5 {TextWidgetCmd procedure, "peer" option} -setup { - text .t -} -body { - .t peer create foo -} -cleanup { - destroy .t -} -returnCodes {error} -result {bad window path name "foo"} -test text-33.6 {TextWidgetCmd procedure, "peer" option} -setup { - text .t - set res {} -} -body { +} {} +test text-31.5 {TextWidgetCmd procedure, "peer" option} { + list [catch {.t peer create foo} msg] $msg +} {1 {bad window path name "foo"}} +test text-31.6 {TextWidgetCmd procedure, "peer" option} { .t peer create .t2 + set res {} lappend res [.t peer names] lappend res [.t2 peer names] destroy .t2 lappend res [.t peer names] -} -cleanup { - destroy .t -} -result {.t2 .t {}} -test text-33.7 {peer widget -start, -end} -body { - text .t - set res [.t configure -start 10 -end 5] - return $res -} -cleanup { - destroy .t -} -returnCodes {2} -result {} -test text-33.8 {peer widget -start, -end} -body { - text .t +} {.t2 .t {}} +test text-31.7 {peer widget -start, -end} { + set res [list [catch {.t configure -start 10 -end 5} msg] $msg] + .t configure -start {} -end {} + set res +} {0 {}} +test text-31.8 {peer widget -start, -end} { + .t delete 1.0 end for {set i 1} {$i < 100} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } - .t configure -start 10 -end 5 -} -cleanup { - destroy .t -} -returnCodes {error} -result {-startline must be less than or equal to -endline} -test text-33.9 {peer widget -start, -end} -body { - text .t + list [catch {.t configure -start 10 -end 5} msg] $msg +} {1 {-startline must be less than or equal to -endline}} +test text-31.9 {peer widget -start, -end} { + .t delete 1.0 end for {set i 1} {$i < 100} {incr i} { .t insert end "Line $i\n" } - .t configure -start 5 -end 10 -} -cleanup { - destroy .t -} -returnCodes {ok} -result {} -test text-33.10 {peer widget -start, -end} -body { - text .t + set res [list [catch {.t configure -start 5 -end 10} msg] $msg] + .t configure -start {} -end {} + set res +} {0 {}} +test text-31.10 {peer widget -start, -end} { + .t delete 1.0 end for {set i 1} {$i < 100} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } set res [.t index end] lappend res [catch {.t configure -start 5 -end 10 -tab foo}] @@ -7110,14 +3746,12 @@ test text-33.10 {peer widget -start, -end} -body { lappend res [.t index end] .t configure -start {} -end {} lappend res [.t index end] - return $res -} -cleanup { - destroy .t -} -result {101.0 1 101.0 1 101.0 101.0} -test text-33.11 {peer widget -start, -end} -body { - text .t + set res +} {101.0 1 101.0 1 101.0 101.0} +test text-31.11 {peer widget -start, -end} { + .t delete 1.0 end for {set i 1} {$i < 100} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } set res [.t index end] lappend res [catch {.t configure -start 5 -end 15}] @@ -7126,19 +3760,16 @@ test text-33.11 {peer widget -start, -end} -body { lappend res [.t index end] .t configure -start {} -end {} lappend res [.t index end] - return $res -} -cleanup { - destroy .t -} -result {101.0 0 11.0 0 31.0 101.0} + set res +} {101.0 0 11.0 0 31.0 101.0} -test text-34.1 {peer widget -start, -end and selection} -setup { - text .t - set res {} -} -body { +test text-32.1 {peer widget -start, -end and selection} { + .t delete 1.0 end for {set i 1} {$i < 100} {incr i} { - .t insert end "Line $i\n" + .t insert end "Line $i\n" } .t tag add sel 10.0 20.0 + set res {} lappend res [.t tag ranges sel] .t configure -start 5 -end 30 lappend res [.t tag ranges sel] @@ -7152,10 +3783,8 @@ test text-34.1 {peer widget -start, -end and selection} -setup { lappend res [.t tag ranges sel] .t configure -start {} -end {} lappend res [.t tag ranges sel] - return $res -} -cleanup { - destroy .t -} -result {{10.0 20.0} {6.0 16.0} {6.0 11.0} {1.0 6.0} {1.0 2.0} {} {10.0 20.0}} + set res +} {{10.0 20.0} {6.0 16.0} {6.0 11.0} {1.0 6.0} {1.0 2.0} {} {10.0 20.0}} test text-32.2 {peer widget -start, -end and deletion (bug 1630262)} -setup { destroy .t .pt @@ -7248,52 +3877,45 @@ test text-32.4 {peer widget -start, -end and deletion (bug 1630262)} -setup { .t delete 3.0 18.0 lappend res [.t cget -start] [.t cget -end] [.pt cget -start] [.pt cget -end] } -cleanup { - destroy .pt .t + destroy .pt } -result {5 11 8 10 5 8 6 8 22 27 38 44 55 60 57 57} -test text-35.1 {widget dump -command alters tags} -setup { - proc Dumpy {key value index} { -#puts "KK: $key, $value" - .t tag add $value [list $index linestart] [list $index lineend] - } - text .t -} -body { +test text-33.1 {widget dump -command alters tags} { + .t delete 1.0 end .t insert end "abc\n" a "---" {} "def" b " \n" {} "ghi\n" c .t tag configure b -background red + proc Dumpy {key value index} { + #puts "KK: $key, $value" + .t tag add $value [list $index linestart] [list $index lineend] + } .t dump -all -command Dumpy 1.0 end set result "ok" -} -cleanup { - destroy .t -} -result {ok} -test text-35.2 {widget dump -command makes massive changes} -setup { +} {ok} +test text-33.2 {widget dump -command makes massive changes} { + .t delete 1.0 end + .t insert end "abc\n" a "---" {} "def" b " \n" {} "ghi\n" c + .t tag configure b -background red proc Dumpy {key value index} { -#puts "KK: $key, $value" + #puts "KK: $key, $value" .t delete 1.0 end } - text .t -} -body { - .t insert end "abc\n" a "---" {} "def" b " \n" {} "ghi\n" c - .t tag configure b -background red .t dump -all -command Dumpy 1.0 end set result "ok" -} -cleanup { - destroy .t -} -result {ok} -test text-35.3 {widget dump -command destroys widget} -setup { - proc Dumpy {key value index} { -#puts "KK: $key, $value" - destroy .t - } - text .t -} -body { +} {ok} +test text-33.3 {widget dump -command destroys widget} { + .t delete 1.0 end .t insert end "abc\n" a "---" {} "def" b " \n" {} "ghi\n" c .t tag configure b -background red + proc Dumpy {key value index} { + #puts "KK: $key, $value" + destroy .t + } .t dump -all -command Dumpy 1.0 end set result "ok" -} -cleanup { - destroy .t -} -result {ok} +} {ok} +deleteWindows +option clear test text-36.1 "bug #1777362: event handling with hyphenated windows" -setup { proc bgerror {m} {set ::my_error $m} @@ -7308,6 +3930,7 @@ test text-36.1 "bug #1777362: event handling with hyphenated windows" -setup { } -cleanup { destroy .t-1 } -result {} + test text-36.2 "bug #1777362: event handling with hyphenated windows" -setup { proc bgerror {m} {set ::my_error $m} set ::my_error {} @@ -7321,6 +3944,7 @@ test text-36.2 "bug #1777362: event handling with hyphenated windows" -setup { } -cleanup { destroy $w } -result {} + test text-36.3 "bug #1777362: event handling with hyphenated windows" -setup { proc bgerror {m} {set ::my_error $m} set ::my_error {} @@ -7334,11 +3958,7 @@ test text-36.3 "bug #1777362: event handling with hyphenated windows" -setup { } -cleanup { destroy $w } -result {} - + # cleanup cleanupTests return - -# Local Variables: -# mode: tcl -# End: |