aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorN.N. <matju@users.sourceforge.net>2009-04-27 05:22:32 +0000
committerN.N. <matju@users.sourceforge.net>2009-04-27 05:22:32 +0000
commita6eaaeae0ef0c0df32062f492b35aa1438fe2163 (patch)
treeb8c7197628882c4c877d4a066f2c9bdb0278efda
parentacce8b4837f8e4d020d1b136ab71d132b5d01a87 (diff)
open modal dialogues subordinate to the last window focused on, rather than always the main window. this fixes a very long-standing annoyance that
will probably persist in other branches of pd for a long time si la tendance se maintient. svn path=/trunk/; revision=11165
-rw-r--r--desiredata/src/desire.tk19
1 files changed, 13 insertions, 6 deletions
diff --git a/desiredata/src/desire.tk b/desiredata/src/desire.tk
index 8cd1f6e1..967abdd5 100644
--- a/desiredata/src/desire.tk
+++ b/desiredata/src/desire.tk
@@ -549,6 +549,13 @@ if {$tk} {
image create bitmap $name -data "#define z_width $w\n#define z_height $h
static unsigned char z_bits[] = { $values };"
}
+
+
+ set main [string toupper [info script] 0 0]
+ bind $main <FocusIn> {set ::current_window %W}
+ bind Toplevel <FocusIn> {set ::current_window %W}
+ proc tk_messageBox2 {args} {tk_messageBox -parent $::current_window {*}$args}
+
# it's unfortunate but we seem to have to turn off global bindings
# for Text objects to get control-s and control-t to do what we want for
# "text" dialogs below. Also we have to get rid of tab's changing the focus.
@@ -958,7 +965,7 @@ proc poll_sock {} {
set cmd [gets $sock]
if {[eof $sock]} {
if {!$cmdline(gdb)} {
- tk_messageBox -message "connection ended by server.\n(crash? try: desire -gdb)" -type ok
+ tk_messageBox2 -message "connection ended by server.\n(crash? try: desire -gdb)" -type ok
}
set sock {}
return
@@ -1171,12 +1178,12 @@ def Client send_message {} {
}
def Client quit {} {
- set answer [tk_messageBox -message "Do you really wish to quit?" -type yesno -icon question]
+ set answer [tk_messageBox2 -message "Do you really wish to quit?" -type yesno -icon question]
switch -- $answer {yes {netsend [list pd quit]; exit}}
}
def Client abort_server {} {
- set answer [tk_messageBox -message "Do you really wish to abort?" -type yesno -icon question]
+ set answer [tk_messageBox2 -message "Do you really wish to abort?" -type yesno -icon question]
switch -- $answer {yes {exec kill -ABRT $::server_pid}}
}
@@ -1504,7 +1511,7 @@ def Canvas close {} {
netsend [list .$self close]
return
}
- switch [tk_messageBox -message [say save_changes?] -icon question -type yesnocancel -default cancel] {
+ switch [tk_messageBox2 -message [say save_changes?] -icon question -type yesnocancel -default cancel] {
yes {$self save; netsend [list .$self close]}
no { netsend [list .$self close]}
cancel {}
@@ -1550,7 +1557,7 @@ def Canvas print {} {
def Canvas quit {} {$::main quit}
def Canvas abort_server {} {$::main abort_server}
-proc wonder {} {tk_messageBox -message [say ask_cool] -type yesno -icon question}
+proc wonder {} {tk_messageBox2 -message [say ask_cool] -type yesno -icon question}
def Canvas eval% {code} {
mset {x y} $@curpos
@@ -8879,7 +8886,7 @@ proc pdtk_savepanel {target localdir} {
#proc bgerror {err} {
# global errorInfo
# set info [error_dump]
-# tk_messageBox -message "$err: $info" -type ok
+# tk_messageBox2 -message "$err: $info" -type ok
#}
class_new OopsDialog {Dialog}