diff options
author | fvogel <fvogelnew1@free.fr> | 2016-05-03 17:12:24 (GMT) |
---|---|---|
committer | fvogel <fvogelnew1@free.fr> | 2016-05-03 17:12:24 (GMT) |
commit | 473bb5cc9b6b28dc7dca5eb9d71b8da7bffac369 (patch) | |
tree | c0830a6a3eb0bed28895c61139b30b1d0943848b /library | |
parent | b1abab58282cc8ff89e73762114369e7a11ce07f (diff) | |
parent | b9aa9a5d2da795de9a7bad7448cc5af7c2c8dd86 (diff) | |
download | tk-473bb5cc9b6b28dc7dca5eb9d71b8da7bffac369.zip tk-473bb5cc9b6b28dc7dca5eb9d71b8da7bffac369.tar.gz tk-473bb5cc9b6b28dc7dca5eb9d71b8da7bffac369.tar.bz2 |
Fixed [011706ec42] - tk::ButtonInvoke safety bug
Diffstat (limited to 'library')
-rw-r--r-- | library/button.tcl | 19 |
1 files changed, 16 insertions, 3 deletions
diff --git a/library/button.tcl b/library/button.tcl index b2bafb2..80d8bf9 100644 --- a/library/button.tcl +++ b/library/button.tcl @@ -597,12 +597,25 @@ proc ::tk::ButtonUp w { # w - The name of the widget. proc ::tk::ButtonInvoke w { - if {[$w cget -state] ne "disabled"} { + if {[winfo exists $w] && [$w cget -state] ne "disabled"} { set oldRelief [$w cget -relief] set oldState [$w cget -state] $w configure -state active -relief sunken - update idletasks - after 100 + after 100 [list ::tk::ButtonInvokeEnd $w $oldState $oldRelief] + } +} + +# ::tk::ButtonInvokeEnd -- +# The procedure below is called after a button is invoked through +# the keyboard. It simulate a release of the button via the mouse. +# +# Arguments: +# w - The name of the widget. +# oldState - Old state to be set back. +# oldRelief - Old relief to be set back. + +proc ::tk::ButtonInvokeEnd {w oldState oldRelief} { + if {[winfo exists $w]} { $w configure -state $oldState -relief $oldRelief uplevel #0 [list $w invoke] } |