/usr/share/tkrat2.2/keydef.tcl is in tkrat 1:2.2cvs20100105-true-dfsg-6ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 | # keydef.tcl --
#
# This file contains code which handles the key definitions window
#
#
# TkRat software and its included text is Copyright 1996-2004 by
# Martin Forssén
#
# The full text of the legal notice is contained in the file called
# COPYRIGHT, included with this distribution.
# The order of the definitions
set keyDefOrder(folder) {folder_key_find folder_key_compose folder_key_replya
folder_key_replys folder_key_forward_i folder_key_forward_a
folder_key_mvdb
folder_key_bounce folder_key_sync folder_key_netsync folder_key_update
folder_key_delete folder_key_undelete folder_key_markunread
folder_key_flag folder_key_nextu folder_key_next folder_key_prev
folder_key_home folder_key_bottom folder_key_pagedown
folder_key_pageup folder_key_linedown folder_key_lineup
folder_key_cycle_header folder_key_print folder_key_close
folder_key_openfile folder_key_online folder_key_quit}
set keyDefOrder(compose) {compose_key_send compose_key_abort
compose_key_editor compose_key_undo compose_key_redo compose_key_cut
compose_key_copy compose_key_paste compose_key_cut_all
compose_key_wrap}
# KeyDef --
#
# Create a key definition window
#
# Arguments:
# area - Identifies the area of keys to define
proc KeyDef {area} {
global option t b keyDefOrder
# Create identifier
set id kd
upvar \#0 $id hd
set w .$id
if {[winfo exists $w]} {
destroy $w
unset hd
}
set hd(do) 0
set hd(state) ""
set hd(w) $w
# Create toplevel
toplevel $w -class TkRat
wm title $w $t(define_keys)
# Buttons
frame $w.but
button $w.but.ok -text $t(ok) -command "KeyDefApply $area $id"
button $w.but.delete -text $t(delete) \
-command "set ${id}(state) delete; set ${id}(message) \"$t(do_delete)\""
button $w.but.cancel -text $t(cancel) -command "destroy $w"
pack $w.but.ok \
$w.but.delete \
$w.but.cancel -side left -expand 1
set b($w.but.ok) ok_and_apply
set b($w.but.delete) keydef_delete
set b($w.but.cancel) cancel
pack $w.but -side bottom -fill x -pady 5
# State line
label $w.msg -textvariable ${id}(message) -relief raised -bd 1
pack $w.msg -side bottom -fill x -pady 5 -padx 10
# The canvas
frame $w.f -relief sunken -bd 1
scrollbar $w.f.scroll \
-relief sunken \
-bd 1 \
-command "$w.f.canvas yview" \
-highlightthickness 0
set hd(canvas) $w.f.canvas
canvas $w.f.canvas \
-yscrollcommand "$w.f.scroll set" \
-highlightthickness 0 \
-background [$w.msg cget -background]
frame $w.f.canvas.f
set hd(cid) [$w.f.canvas create window 0 0 \
-anchor nw \
-window $w.f.canvas.f]
set fr $w.f.canvas.f
pack $w.f.scroll -side right -fill y
pack $w.f.canvas -side left -expand 1 -fill both
pack $w.f -fill both
# Create key windows
foreach n $keyDefOrder($area) {
set hd($n) $option($n)
label ${fr}.${n}_label -text $t($n) -anchor e
button ${fr}.${n}_button -text $t(add_key) \
-command "AddKey ${fr}.${n}_f $n $id"
set b(${fr}.${n}_button) keydef_add
frame ${fr}.${n}_f -relief sunken -bd 1
set b(${fr}.${n}_f) keydef_def
grid ${fr}.${n}_label ${fr}.${n}_f ${fr}.${n}_button -sticky we -pady 5
set hd(w_${n}) ${fr}.${n}_f
PopulateKeyDef ${fr}.${n}_f $n $id
if {![llength $hd($n)]} {
button ${fr}.${n}_f.b -relief flat -state disabled
pack ${fr}.${n}_f.b
}
}
grid columnconfigure $w.f.canvas 1 -weight 1
bind $w.f.canvas <Destroy> "KeyDefClose $id"
::tkrat::winctl::SetGeometry keydef $w $w.f.canvas
# Resize canvas
update idletasks
set bbox [$hd(canvas) bbox $hd(cid)]
eval {$hd(canvas) configure -scrollregion $bbox}
}
# PopulateKeyDef --
#
# Populates one keydef function
#
# Arguments:
# w - The frame to add the keys in
# name - The name of the definitions
# handler - The handler for this keydef window
proc PopulateKeyDef {w name handler} {
global idCnt b
upvar \#0 $handler hd
foreach s [pack slaves $w] {
destroy $s
}
foreach k $hd($name) {
set hd($k) $name
regsub {Key-} $k {} key
set bn $w.b[incr idCnt]
button $bn -text [string trim $key {<>}] -bd 1 \
-command "DeleteKeyDef $k $handler"
pack $bn -side left -pady 2 -padx 2
set b($bn) keydef_def
}
}
# AddKey --
#
# Add a new key combination
#
# Arguments:
# w - The frame to add the keys in
# name - The name of the definitions
# handler - The handler for this keydef window
proc AddKey {w name handler} {
upvar \#0 $handler hd
global t
set hd(mod) ""
set hd(state) ""
set hd(message) ""
pack propagate $w 0
foreach s [pack slaves $w] {
destroy $s
}
label $w.label -text $t(press_key)
set hd(state) $t(press_key)
pack $w.label -expand 1
bind $w.label <KeyPress> "KeyEvent p %K $w $name $handler; break"
bind $w.label <KeyRelease> "KeyEvent r %K $w $name $handler; break"
focus $w.label
}
# KeyEvent --
#
# Handle a key press or key release.
#
# Arguments:
# e - Which event
# key - The keysym
# w - The frame to add the keys in
# name - The name of the definitions
# handler - The handler for this keydef window
proc KeyEvent {e key w name handler} {
upvar \#0 $handler hd
global t
if {[regexp {(Shift|Control|Alt|Mod[1-5]|Meta)(_[LR])?} $key tot mod]} {
if {[string compare p $e]} {
regsub "$mod-" $hd(mod) {} hd(mod)
} else {
set hd(mod) "$mod-$hd(mod)"
}
} elseif {[string compare r $e]} {
set event "<$hd(mod)Key-$key>"
set hd(state) ""
if {[info exists hd($event)]} {
# The key already exists
set oname $hd($event)
if { 0 == [RatDialog [winfo toplevel $w] $t(add_key) \
"$t(key_defined) $t($oname)" {} 0 \
$t(replace_key) $t(cancel)]} {
# Remove old definition and update it
set i [lsearch $hd($oname) $event]
set hd($oname) [lreplace $hd($oname) $i $i]
PopulateKeyDef $hd(w_$oname) $oname $handler
lappend hd($name) $event
set hd($event) $name
}
} else {
lappend hd($name) $event
set hd($event) $name
}
destroy [pack slaves $w]
PopulateKeyDef $w $name $handler
pack propagate $w 1
}
}
# DeleteKeyDef --
#
# Delete a key definition
#
# Arguments:
# event - The key event that should be deleted
# handler - The handler for the keydef window
proc DeleteKeyDef {event handler} {
upvar \#0 $handler hd
if {[string compare delete $hd(state)]} {
return
}
set name $hd($event)
set i [lsearch $hd($name) $event]
set hd($name) [lreplace $hd($name) $i $i]
PopulateKeyDef $hd(w_$name) $name $handler
unset hd($event)
set hd(state) ""
set hd(message) ""
}
# KeyDefApply --
#
# Apply the key definitions
#
# Arguments:
# area - Identifies the area of keys to define
# handler - The handler for this keydef window
proc KeyDefApply {area handler} {
upvar \#0 $handler hd
global option b
set changed 0
set remove {}
foreach n [array names hd ${area}_key_*] {
if {[string compare $option($n) $hd($n)]} {
foreach e $option($n) {
if { -1 == [lsearch $hd($n) $e]} {
lappend remove $e
}
}
set option($n) $hd($n)
set changed 1
}
}
destroy $hd(w)
if {$changed} {
switch $area {
folder {
global folderWindowList
foreach f [array names folderWindowList] {
upvar \#0 $f fh
foreach e $remove {
bind $fh(w) $e {}
}
FolderBind $f
}
}
compose {
global composeWindowList
foreach m $composeWindowList {
upvar \#0 $m mh
foreach e $remove {
bind $mh(toplevel) $e {}
}
ComposeBind $m
}
}
}
SaveOptions
}
}
# KeyDefClose --
#
# Close the key definition window
#
# Arguments:
# handler - The handler for this keydef window
proc KeyDefClose {handler} {
upvar \#0 $handler hd
::tkrat::winctl::RecordGeometry keydef $hd(w) $hd(canvas)
foreach bn [array names b $hd(w).*] {unset b($bn)}
unset hd
}
|