mc/tk/mc.tcl
1998-02-27 04:54:42 +00:00

1384 lines
36 KiB
Tcl

# Midnight Commander Tk code.
# Copyright (C) 1995, 1996, 1997 Miguel de Icaza
#
#
# Todo:
# Fix the internal viewer
# Missing commands: mc_file_info, mc_open_with
# The default buttons have a problem with the new frame around them:
# they don't display the focus.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
wm iconname . tkmc
wm title . "Midnight Commander (TK edition)"
#
# Menu routines
#
proc create_top_menu {} {
global top_menus
global setup
set top_menus ""
frame .mbar -relief raised -bd 2
pack .mbar -side top -fill x
}
#
# Widget: WMenu
#
proc create_menu {str topmenu} {
global top_menus
global setup
menubutton .mbar.$topmenu -text $str -underline 0 -menu .mbar.$topmenu.menu
pack .mbar.$topmenu -side left
menu .mbar.$topmenu.menu -tearoff $setup(tearoff)
set top_menus "$top_menus $topmenu"
}
proc create_mentry {topmenu entry cmd idx} {
.mbar.$topmenu.menu add command -label "$entry" -command "$cmd $idx"
}
proc add_separator {topmenu} {
.mbar.$topmenu.menu add separator
}
#
# Widget: WButton
#
proc newbutton {name cmd text isdef} {
if $isdef {
frame $name -relief sunken -bd 1
set name "$name.button"
}
button $name -text "$text" -command $cmd -justify left
if $isdef {
pack $name -padx 1m -pady 1m
}
}
#
# Widget: WGauge
#
proc newgauge {win} {
global setup
canvas $win -height $setup(heightc) -width 250 -relief sunken -border 2
$win create rectangle 0 0 0 0 -tags gauge -fill black -stipple gray50
# So that we can tell the C code, which is the gauge size currently
bind $win <Configure> "x$win %w"
}
# Used to show the gauge information
proc gauge_shown {win} {
# $win configure -relief sunken -border 2
}
# Used to hide the gauge information.
proc gauge_hidden {win} {
# $win configure -relief flat -border 0
$win coords gauge 0 0 0 0
}
#
# Widget: WView
#
proc view_size {cmd w h} {
global setup
$cmd dim [expr $w/$setup(widthc)] [expr $h/$setup(heightc)]
}
proc newview {is_panel container winname cmd} {
global setup
# FIXME: The trick to get the window without too much
# movement/flicker is to use an extra frame, and use the placer
# like it was done in WInfo.
if $is_panel {
set width [expr [winfo width $container]/$setup(widthc)]
set height [expr [winfo height $container]/$setup(heightc)]
}
frame $winname
frame $winname.v
frame $winname.v.status
eval text $winname.v.view $setup(view_normal) -font $setup(panelfont)
# Create the tag names for the viewer attributes
eval $winname.v.view tag configure bold $setup(view_bold)
eval $winname.v.view tag configure underline $setup(view_underline)
eval $winname.v.view tag configure mark $setup(view_mark)
eval $winname.v.view tag configure normal $setup(view_normal)
# Make the status fields
label $winname.v.status.filename
label $winname.v.status.column
label $winname.v.status.size
label $winname.v.status.flags
pack $winname.v.status.filename -side left
pack $winname.v.status.column -anchor w -side left -fill x -expand 1
pack $winname.v.status.size -anchor w -side left -fill x -expand 1
pack $winname.v.status.flags -anchor w -side left -fill x -expand 1
# Pack the main components
pack $winname.v.status -side top -fill x
pack $winname.v.view -side bottom -expand 1 -fill both
pack $winname.v -expand 1 -fill both
bindtags $winname.v.view "all . $winname.v.view"
bind $winname.v.view <Configure> "view_size $cmd %w %h"
if $is_panel {
$winname.v.view configure -width $width -height $height
pack $winname
}
}
proc view_update_info {win fname col size flags} {
$win.v.status.filename configure -text "File: $fname"
$win.v.status.column configure -text "Column: $col"
$win.v.status.size configure -text "$size bytes"
$win.v.status.flags configure -text "$flags"
}
#
# Hack: remove all the text on the window and then insert
# new lines. Maybe the newlines
proc cleanview {win} {
$win delete 1.0 end
$win insert 1.0 "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n"
}
#
# Widget: WRadio
#
proc newradio {name} {
frame $name
global last_radio
set last_radio $name
}
proc radio_item {idx text cmd act} {
global last_radio
radiobutton $last_radio.$idx -text "$text" -variable v$last_radio -value $idx -command "$cmd select $idx"
if $act {
$last_radio.$idx select
}
pack $last_radio.$idx -side top -anchor w
}
#
# Widget: Input
#
#
proc entry_save_sel {win} {
global sel
if [$win selection present] {
set sel(pres) 1
set sel(first) [$win index sel.first]
set sel(last) [$win index sel.last]
} else {
set sel(pres) 0
}
}
proc entry_restore_sel {win} {
global sel
if $sel(pres) {
$win selection from $sel(first)
$win selection to $sel(last)
}
}
proc entry_click {win x} {
global sel
set p [$win index @$x]
x$win mouse $p
x$win setmark
set sel(from) $p
}
proc entry_move {win x} {
global sel
set p [$win index @$x]
$win selection from $sel(from)
$win selection to $p
x$win mouse $p
}
proc bind_entry {win} {
bind $win <1> "entry_click $win %x"
bind $win <B1-Motion> "entry_move $win %x"
}
proc newinput {name text} {
entry $name -relief sunken -background white -foreground black
$name insert 0 "$text"
bindtags $name "all . $name "
bind_entry $name
}
#
# Widget: WCheck
#
proc newcheck {name cmd text act} {
checkbutton $name -text "$text" -command "$cmd"
if $act { $name select }
}
#
# Widget: WInfo
#
# window is the container name and widget name: .left.o2
# container is the container name: .left
#
proc info_entry {win name text} {
frame $win.b.finfo.$name
label $win.b.finfo.$name.label -text "$text"
label $win.b.finfo.$name.info
grid $win.b.finfo.$name.label -row 0 -column 0 -sticky we
grid $win.b.finfo.$name.info -row 0 -column 1 -sticky w
grid columnconfigure $win.b.finfo.$name 0 -minsize 100
}
proc newinfo {container window version} {
global setup
set width [winfo width $container]
set height [winfo height $container]
frame $window -width $width -height $height \
-borderwidth [expr $setup(widthc)/2]
frame $window.b
frame $window.b.v
frame $window.b.finfo -relief groove -borderwidth 2
frame $window.b.fs -relief groove -borderwidth 2
label $window.b.v.version -text " The Midnight Commander $version " \
-relief groove
pack $window.b.v.version -fill x
info_entry $window fname "File:"
info_entry $window location "Location:"
info_entry $window mode "Mode:"
info_entry $window links "Links:"
info_entry $window owner "Owner:"
info_entry $window size "Size:"
info_entry $window created "Created:"
info_entry $window modified "Modified:"
info_entry $window access "Access:"
pack $window.b.finfo.fname \
$window.b.finfo.location $window.b.finfo.mode $window.b.finfo.links \
$window.b.finfo.owner $window.b.finfo.size $window.b.finfo.created \
$window.b.finfo.modified $window.b.finfo.access \
-side top -anchor w
label $window.b.fs.fsys
label $window.b.fs.dev
label $window.b.fs.type
frame $window.b.fs.free
label $window.b.fs.free.label
newcanvas $window.b.fs.free.canvas
pack $window.b.fs.free.label -side left
pack $window.b.fs.free.canvas -side left
frame $window.b.fs.freeino
label $window.b.fs.freeino.label
newcanvas $window.b.fs.freeino.canvas
pack $window.b.fs.freeino.label -side left
pack $window.b.fs.freeino.canvas -side left
pack $window.b.fs.fsys \
$window.b.fs.dev $window.b.fs.type \
$window.b.fs.free \
$window.b.fs.freeino -side top -anchor w -padx $setup(widthc)
pack $window.b.v -side top -anchor w -fill x -expand 1
pack $window.b.fs -side bottom -anchor w -fill x -expand 1
pack $window.b.finfo -side top -anchor w \
-fill x -expand 1
pack $window.b
pack $window -fill both -expand 1
# pack $window.b
place $window.b -in $window -relx 0 -rely 0 -relheight 1 -relwidth 1
}
proc info_bar {win percent} {
global setup
set w [winfo width $win]
set s [expr (100-$percent)*$w/100]
$win coords bar 0 0 $s 50
# puts stderr "Width: $w $s\n\r"
}
proc info_none {win} {
$win coords bar 0 0 0 0
}
proc newcanvas {win} {
global setup
canvas $win -height $setup(heightc) -relief sunken -border 2
$win create rectangle 0 0 0 0 -tags bar -fill black -stipple gray50
}
proc infotext {win text} {
$win configure -text $text
}
proc xinfotext {win text} {
$win.info configure -text $text
}
# w containes the window name *and* the .b frame (like: .left.o2.b)
# FIXME: We should also display the rdev information
proc info_update {w
fname dev ino
mode mode_oct
links owner group
have_blocks blocks
size
have_rdev rdev rdev2
create modify access
fsys dev type
have_space avail percent total
have_ino nfree inoperc inotot} {
#
# Set all the text information
#
xinfotext $w.finfo.fname "$fname"
xinfotext $w.finfo.location "${dev}h:${ino}h"
xinfotext $w.finfo.mode "$mode ($mode_oct)"
xinfotext $w.finfo.links "$links"
xinfotext $w.finfo.owner "$owner/$group"
if $have_blocks {
xinfotext $w.finfo.size "$size ($blocks blocks)"
} else {
xinfotext $w.finfo.size "$size"
}
xinfotext $w.finfo.created "$create"
xinfotext $w.finfo.modified "$modify"
xinfotext $w.finfo.access "$access"
infotext $w.fs.fsys "Filesystem:\t$fsys"
infotext $w.fs.dev "Device:\t\t$dev"
infotext $w.fs.type "Type:\t\t$type"
if $have_space {
infotext $w.fs.free.label \
"Free Space $avail ($percent%) of $total"
info_bar $w.fs.free.canvas $percent
} else {
infotext $w.fs.free.label "No space information"
info_none $w.fs.free.canvas
}
if $have_ino {
infotext $w.fs.freeino.label \
"Free inodes $nfree ($inoperc%) of $inotot"
info_bar $w.fs.freeino.canvas $inoperc
} else {
infotext $w.fs.freeino.label "No inode information"
info_none $w.fs.freeino.canvas
}
}
#
# Widget: listbox
#
proc listbox_sel {win item} {
$win selection clear 0 end
$win selection set $item
$win see $item
}
#
# Widget: WPanel
#
proc panel_select {w pos cback} {
$w.m.p.panel tag add selected $pos.0 "$pos.0 lineend"
$w.m.p.panel see $pos.0
$cback top [$w.m.p.panel index @0,0]
}
proc panel_scroll {win cback args} {
eval "$win yview $args"
$cback top [$win index @0,0]
}
proc cmd_sort_add {name menu cmd} {
$menu add command -label $name -command "$cmd sort $name"
}
proc panel_setup {which cmd} {
global setup
frame $which
set m $which.cwd.menu
menubutton $which.cwd -text "loading..." -bd 1 -relief raised \
-menu $m -indicatoron 0
menu $m -tearoff 0
menu [set mm $m.sort] -tearoff 0
$m add command -label "Reverse sort order" -command "$cmd reverse"
$m add cascade -label "Sort" -menu $mm
cmd_sort_add "Name" $mm $cmd
cmd_sort_add "Extension" $mm $cmd
cmd_sort_add "Size" $mm $cmd
cmd_sort_add "Modify Time" $mm $cmd
cmd_sort_add "Access Time" $mm $cmd
cmd_sort_add "Change Time" $mm $cmd
cmd_sort_add "Inode" $mm $cmd
cmd_sort_add "Type" $mm $cmd
cmd_sort_add "Links" $mm $cmd
cmd_sort_add "NGID" $mm $cmd
cmd_sort_add "NUID" $mm $cmd
cmd_sort_add "Owner" $mm $cmd
cmd_sort_add "Group" $mm $cmd
cmd_sort_add "Unsorted" $mm $cmd
$m add command -label "Refresh" -command "$cmd refresh"
$m add separator
$m add command -label "Set mask" -command "$cmd setmask"
$m add command -label "No mask" -command "$cmd nomask"
frame $which.m
label $which.mini
scrollbar $which.m.scroll -width 3m
frame $which.m.p -relief sunken -borderwidth 2
# The sort bar
if $setup(with_sortbar) {
canvas $which.m.p.types \
-borderwidth 0\
-back $setup(def_back) \
-highlightthickness 0 -height 0
pack $which.m.p.types -side top -fill x
}
scrollbar $which.m.p.scroll -width 3m -orient horizontal
# The file listing panel
text $which.m.p.panel -width $setup(cols) -yscroll "$which.m.scroll set" \
-fore $setup(def_fore) -back $setup(def_back) \
-wrap none -height $setup(lines) -font $setup(panelfont) \
-relief flat -borderwidth 0 -highlightthickness 0 \
-xscroll "$which.m.p.scroll set"
bindtags $which.m.p.panel "all . $which.m.p.panel"
proc x$which.m.p.panel {x} "$cmd \$x"
pack $which.m.p.panel -side top -fill both -expand 1
pack $which.m.p.scroll -side top -fill x
pack $which.m.p -side left -fill both -expand 1
pack $which.m.scroll -side right -fill y
pack $which.cwd -side top -anchor w
pack $which.m -side top -fill both -expand 1
pack $which.mini -side top -fill x
pack $which -fill both -expand 1
config_colors $which.m.p.panel
}
#
# Draging the panels:
# mc_x and mc_y contains the last positions where the mouse was
# mc_repeat contains the id of the after command.
#
proc panel_cancel_repeat {} {
global mc_repeat
after cancel $mc_repeat
set mc_repeat {}
}
proc panel_drag {w cmd n} {
global mc_y
global mc_x
global mc_repeat
if {$mc_y >= [winfo height $w]} {
$w yview scroll 1 units
} elseif {$mc_y < 0} {
$w yview scroll -1 units
} else {
return
}
$cmd top [$w index @0,0]
$cmd motion $n [$w index @$mc_x,$mc_y]
set mc_repeat [after 50 panel_drag $w $cmd $n]
}
#
# This routine passes the size of the text widget back to the C code
#
proc panel_size {cmd panel w h} {
global setup
set setup(real_height) $h
set setup(real_width) $w
if $setup(with_icons) {
set setup(height) [expr $h-setup(iconheight)]
set setup(width) [expr $w-$setup(iconwidth)]
set setup(lines) [expr $setup(height)/$setup(heightc)]
set setup(cols) [expr $setup(width)/$setup(widthc)]
} else {
set setup(height) $h
set setup(width) $w
set setup(lines) [expr $h/$setup(heightc)]
set setup(cols) [expr $w/$setup(widthc)]
}
$cmd resize $panel
}
#
# Called on the first idle loop to configure the sizes of the thing
#
proc panel_conf {panel cmd} {
global setup
set font [lindex [$panel configure -font] 4]
set fontinfo [$cmd fontdim $font $panel]
set setup(heightc) [lindex $fontinfo 0]
set setup(widthc) [lindex $fontinfo 1]
bind $panel <Configure> "panel_size $cmd $panel %w %h"
}
#
# Manage the bar that keeps the sort orders
#
proc panel_reset_sort_labels {win} {
# $win.m.p.types delete all
}
proc panel_sort_label_start {win} {
# $win.m.p.types delete all
}
#
# This right now uses a canvas, creates labels and places them
# on the canvas. The button emulation is done with a manual
# bind.
#
proc panel_add_sort {win text_len text pos end_pos tag} {
global setup
if {$setup(with_sortbar) == 0} return
catch { destroy $win.m.p.types.$pos }
label $win.m.p.types.$pos -text $text -borderwidth 2 \
-font $setup(panelfont) -relief raised
$win.m.p.types create window $pos 0 -window $win.m.p.types.$pos -anchor nw
$win.m.p.types configure -height [expr $setup(heightc)+8]
$win.m.p.types create line $end_pos 1 $end_pos [expr $setup(heightc)-1] -fill gray
# Simulate the button.
bind $win.m.p.types.$pos <Button-1> "
$win.m.p.types.$pos configure -relief sunken
x$win sort $tag
after 100 { $win.m.p.types.$pos configure -relief raised }
"
}
#
# Called back from the action menu
#
proc popup_add_action {filename cmd idx} {
global setup
menu [set m .m.action] -tearoff 0
.m add cascade -foreground $setup(action_foreground) -label "$filename" -menu $m
$m add command -label "Info" -command "mc_file_info \"$filename\""
$m add command -label "Open with..." -command "mc_open_with \"$filename\""
$m add separator
$m add command -label "Copy..." -command "$cmd invoke %d Copy"
$m add command -label "Rename, move..." -command "$cmd invoke %d Move"
$m add command -label "Delete..." -command "$cmd invoke %d Delete"
$m add separator
$m add command -label "Open" -command "$cmd invoke %d Open"
$m add command -label "View" -command "$cmd invoke %d View"
}
proc start_drag {mode panel_cmd W x y X Y} {
global drag_mode
global drag_text
set drag_mode $mode
set drag_text [$panel_cmd dragtext [$W index @$x,$y]]
set drag_text "$mode $drag_text"
catch {destroy .drag}
toplevel .drag
wm overrideredirect .drag 1
wm withdraw .drag
label .drag.text -text "$drag_text"
pack .drag.text
wm deiconify .drag
wm geometry .drag +$X+$Y
}
proc drag_test {token} {
if {[winfo children $token] == ""} {
label $token.value -text "Zonzo"
pack $token.value
}
$token.value configure -text Hla
return "caca";
}
proc mc_drag_target {} {
global DragDrop
set data $DragDrop(text)
}
proc mc_drag_send {} {
# puts "drag send"
}
#
# Mouse bindings for the panels
#
proc panel_bind {the_panel panel_cmd} {
global setup
set pn "$the_panel.m.p.panel"
bind $pn <Button-1> "
$panel_cmd mdown 2 \[%W index @%x,%y]
"
bind $pn <ButtonRelease-1> "
panel_cancel_repeat
$panel_cmd mup 2 \[%W index @%x,%y]"
bind $pn <Double-1> "
panel_cancel_repeat
$panel_cmd double 2 \[%W index @%x,%y]"
bind $pn <B1-Motion> "
set mc_x %x
set mc_y %y
$panel_cmd motion 2 \[%W index @%x,%y]
"
bind $pn <B1-Leave> "
set mc_x %x
set mc_y %y
panel_drag %W $panel_cmd 2
"
bind $pn <B1-Enter> panel_cancel_repeat
if $setup(b2_marks) {
bind $pn <Button-2> "
$panel_cmd mdown 1 \[%W index @%x,%y]"
bind $pn <ButtonRelease-2> "
$panel_cmd mup 1 \[%W index @%x,%y]
panel_cancel_repeat
"
bind $pn <B2-Motion> "
set mc_x %x
set mc_y %y
$panel_cmd motion 1 \[%W index @%x,%y]
"
bind $pn <B2-Leave> "
set mc_x %x
set mc_y %y
panel_drag %W $panel_cmd 1
"
} else {
# We have blt
# blt_drag&drop source $pn config -button 2 -packagecmd drag_test \
# -selftarget 1
# blt_drag&drop source $pn handler text dd_send_file
}
# Menu popup.
bind $pn <Button-3> "
$panel_cmd mdown 2 \[%W index @%x,%y]
catch {destroy .m}
menu .m -tearoff 0
$panel_cmd load \[%W index @%x,%y] %X %Y
#Buggy Tk8.0
catch {tk_popup .m %X %Y}
"
bind $pn <B2-Enter> panel_cancel_repeat
$the_panel.m.scroll configure \
-command "panel_scroll $pn $panel_cmd"
$the_panel.m.p.scroll configure \
-command "$pn xview"
panel_conf $pn $panel_cmd
}
proc panel_info {item} {
global setup
return $setup($item)
}
proc panel_mark {tag panel n} {
config_colors $panel
$panel tag add $tag "${n}.0" "${n}.0 lineend"
}
# op is add or remove
proc panel_mark_entry {win op line} {
$win.m.p.panel tag $op marked $line.0 "$line.0 lineend"
}
proc panel_unmark_entry {win line} {
$win.m.p.panel tag remove selected $line.0 "$line.0 lineend"
}
#
# Misc routines
#
# Configure the panel tags
proc config_colors {which} {
global setup
# se -- selected file
$which tag configure selected -back $setup(panelcolor,selected_back)
foreach v {marked directory executable regular selected} {
$which tag configure $v -fore $setup(panelcolor,$v)
}
$which tag configure directory -font $setup(paneldir)
$which tag raise marked
}
proc tclerror {msg} {
puts stderr "TkError: [$msg]\n\r"
}
#
# FIXME: This is not finished, have to deal with activefore, activeback
# highlight{fore,back}
#
proc error_colors {wins} {
global setup
foreach widget $wins {
catch "$widget configure -foreground $setup(errorfore)"
catch "$widget configure -background $setup(errorback)"
}
}
#
#
# Layout routines
#
#
proc layout_midnight {} {
global one_window
global wlist
#puts $wlist
#
# we want to make the prompt and the input line sunken
# so we sunk the frame, and set a borderwidth for it
# while removing the sunken attribute set by the newinput
.p.i0 configure -relief flat
.p configure -relief sunken -borderwidth 2
pack .p.l5 -side left
pack .p.i0 -side left -expand 1 -fill x -anchor e
pack .n4 -side bottom -fill x
pack .p -side bottom -fill x
if $one_window {
pack .left -side top -side left -fill both -expand 1
pack .right -side top -side right -fill both -expand 1
}
}
proc layout_query {} {
global wlist
# puts "$wlist"
set t [llength $wlist]
if {$t == 2} {
pack .query.l1 -side top -pady 2m -padx 2m
pack .query.b0 -side right -ipadx 2m -padx 4m -pady 2m -expand 1
} else {
pack .query.l1 -side top -pady 2m -padx 2m
for {set b 2} {$b != 1} {incr b} {
if {$b == $t} {
set b 0
}
pack .query.b$b -side right -ipadx 2m -padx 4m -pady 2m -expand 1
}
}
}
proc layout_listbox {} {
scrollbar .listbox.s -width 3m -command {.listbox.x0 yview}
.listbox.x0 configure -yscroll {.listbox.s set}
pack .listbox.s -fill y -side right
pack .listbox.x0 -expand 1 -fill both -padx 4m -pady 4m -side left
}
proc layout_quick_confirm {} {
pack .quick_confirm.c.c1 .quick_confirm.c.c2 .quick_confirm.c.c3 \
-side top -anchor w
pack .quick_confirm.b.b0 .quick_confirm.b.b4 -side left -padx 4m -expand 1
pack .quick_confirm.c -side top -pady 4m
pack .quick_confirm.b -side top -pady 2m
}
proc layout_quick_file_mask {} {
global wlist
# puts stderr "$wlist"
# We add some space
.quick_file_mask configure -borderwidth 5m
pack .quick_file_mask.b.b1 .quick_file_mask.b.b2 \
-side left -expand 1 -padx 4m
pack .quick_file_mask.l3 -side top -anchor w -expand 1
pack .quick_file_mask.s.i5 -fill x -expand 1 -anchor w
pack .quick_file_mask.s.c6 -anchor e -padx 4m -pady 1m
pack .quick_file_mask.s -expand 1 -fill x -side top
pack .quick_file_mask.d.l7 -pady 4m
pack .quick_file_mask.d -side top -anchor w
pack .quick_file_mask.i4 -expand 1 -fill x -side top
pack .quick_file_mask.t.c8 .quick_file_mask.t.c0 -side top -anchor e
catch {pack .quick_file_mask.t.c9 -side top -anchor e}
pack .quick_file_mask.t -side top -anchor e
frame .quick_file_mask.space -height 4m
pack .quick_file_mask.space -side top
pack .quick_file_mask.b -fill x -expand 1 -side top
}
proc layout_quick_vfs {} {
global wlist
# puts stderr "$wlist"
pack .quick_vfs.t.l1 -side left
pack .quick_vfs.t.i2 -side left -expand 1 -fill x -padx 2m
pack .quick_vfs.t.l3 -side left
pack .quick_vfs.l.l4 -side top -anchor w
pack .quick_vfs.l.r5 -side left -anchor w
pack .quick_vfs.l.i6 -side right -anchor se
pack .quick_vfs.b.b7 .quick_vfs.b.b0 -padx 4m -side left -expand 1
pack .quick_vfs.t -side top -expand 1 -fill x -pady 4m -padx 4m
pack .quick_vfs.l -side top -expand 1 -fill x -padx 4m
pack .quick_vfs.b -side top -expand 1 -fill x -padx 4m -pady 4m
}
proc layout_dbits {} {
pack .dbits.r1 -anchor w -padx 4m -pady 4m -side top
pack .dbits.b0 -side top
}
proc layout_chown {} {
global setup
pack .chown.b.b8 .chown.b.b0 -side left -padx 4m -expand 1
# May be invoked with different number of buttons
# There is already a problem: the cancel button is
# not close to the ok button, I will have to look into this.
catch {
pack .chown.b.b9 .chown.b.b10 .chown.b.b11 \
-side left -padx 4m -expand 1
}
label .chown.l.fname -text {File name}
label .chown.l.owner -text {Owner name}
label .chown.l.group -text {Group name}
label .chown.l.size -text {Size}
label .chown.l.perm -text {Permission}
pack \
.chown.l.fname .chown.l.l7 \
.chown.l.owner .chown.l.l6 \
.chown.l.group .chown.l.l5 \
.chown.l.size .chown.l.l4 \
.chown.l.perm .chown.l.l3 -side top -anchor w -padx 2m
foreach i {l3 l4 l5 l6 l7} {
.chown.l.$i configure -fore $setup(high)
}
pack .chown.l.l3 .chown.l.l4 .chown.l.l5 .chown.l.l6 .chown.l.l7 \
-side top -pady 1m -padx 4m -anchor w
# Configure the listboxes
scrollbar .chown.f.s -width 3m -command {.chown.f.x2 yview}
.chown.f.x2 configure -yscroll {.chown.f.s set}
label .chown.f.l -text {Group name}
pack .chown.f.l -side top -anchor w
pack .chown.f.x2 -side left -fill y -expand 1
pack .chown.f.s -side right -fill y -expand 1
scrollbar .chown.g.s -width 3m -command {.chown.g.x1 yview}
.chown.g.x1 configure -yscroll {.chown.g.s set}
label .chown.g.l -text {User name}
pack .chown.g.l -side top -anchor w
pack .chown.g.x1 -side left -fill y -expand 1
pack .chown.g.s -side right -fill y -expand 1
.chown.b configure -relief sunken
pack .chown.b -side bottom -pady 4m -fill x
pack .chown.g .chown.f -side left -padx 4m -pady 4m -expand 1 -fill y
pack .chown.l -side right -padx 4m
}
proc layout_chmod {} {
global wlist
# puts stderr "$wlist \n\r"
pack .chmod.c.c5 .chmod.c.c6 .chmod.c.c7 .chmod.c.c8 .chmod.c.c9 \
.chmod.c.c10 \
.chmod.c.c11 .chmod.c.c12 .chmod.c.c13 .chmod.c.c14 .chmod.c.c15 \
.chmod.c.c16 -side top -anchor w
pack .chmod.b.b17 .chmod.b.b0 -side left -padx 4m -pady 4m -side left
catch {
pack .chmod.b.b18 .chmod.b.b19 .chmod.b.b19 .chmod.b.b20 \
.chmod.b.b21 -side left -padx 4m -pady 4m -side left
}
label .chmod.l.msg -text {Use "t" or Insert to\nmark attributes}
label .chmod.l.fname -text {Name}
label .chmod.l.perm -text {Permission (octal)}
label .chmod.l.owner -text {Owner name}
label .chmod.l.group -text {Group name}
pack \
.chmod.l.fname .chmod.l.l4 \
.chmod.l.perm .chmod.l.l1 \
.chmod.l.owner .chmod.l.l3 \
.chmod.l.group .chmod.l.l2 .chmod.l.msg -side top -anchor w -padx 2m
pack .chmod.b -side bottom
pack .chmod.l -side right -padx 4m -anchor n -pady 4m
pack .chmod.c -side left -padx 4m -pady 4m
}
proc layout_view {} {
global wlist
pack [lindex $wlist 0] -side bottom -fill x
pack [lindex $wlist 1] -side top -expand 1 -fill both
}
proc layout_replace {} {
global wlist
error_colors "$wlist .replace"
set alist {}
set plist {}
set ilist {}
foreach a $wlist {
if [regexp ^.replace.p.l $a] {
set plabel $a
} elseif [regexp ^.replace.p $a] {
set plist "$plist $a"
} elseif [regexp ^.replace.a.l $a] {
set alabel $a
} elseif [regexp ^.replace.a $a] {
set alist "$alist $a"
} elseif [regexp ^.replace.i $a] {
set ilist "$ilist $a"
} elseif [regexp ^.replace.b $a] {
set abortbutton $a
} else {
set fname $a
}
}
# puts stderr "$wlist\n\r"
# puts stderr "alist: $alist\n\rplist: $plist\n\rilist: $ilist\n\r"
# puts stderr "plabel: $plabel\n\rfname: $fname"
pack $fname -side top -fill x -anchor w -pady 6m -padx 12m
pack $abortbutton -side bottom -anchor e -padx 8m -pady 4m
eval pack $ilist -side top -anchor w
pack .replace.i -padx 10m -pady 2m -anchor w
pack $plabel -side left -anchor w -padx 10m
eval pack $plist -side left -anchor e -fill x
pack .replace.p -side top -fill x -padx 10m
pack $alabel -side left -anchor w -padx 10m
eval pack $alist -side left -anchor e -fill x
pack .replace.a -side top -fill x -padx 10m
}
proc layout_complete {} {
global wlist
eval pack $wlist -side top
}
proc layout_opwin {} {
global wlist
global setup
pack .opwin.b.b0 .opwin.b.b14 -side left -expand 1
pack .opwin.f0.l1 .opwin.f0.l2 -side left -anchor w
pack .opwin.f1.l3 .opwin.f1.l4 -side left -anchor w
foreach a {.opwin.2.l11 .opwin.1.l8 .opwin.0.l5} {
$a configure -width 8
}
pack .opwin.2.l11 .opwin.2.g13 -side left -fill x
pack .opwin.1.l8 .opwin.1.g10 -side left -fill x
pack .opwin.0.l5 .opwin.0.l6 -side left -fill x
pack .opwin.b -side bottom -pady 4m -fill x
pack .opwin.f0 -side top -padx 10m -anchor w
pack .opwin.f1 -side top -padx 10m -pady 4m -anchor w
pack .opwin.0 .opwin.1 .opwin.2 -side top -padx 4m
}
proc dummy_layout {name} {
eval "proc layout_$name {} {
global wlist
# puts stderr \"\$wlist \\n\"
eval pack \$wlist -side top}"
}
#
# the achown commands will have to be rewriten
# to use only widgets and no writing callbacks.
#
foreach i {
achown tree
} {
dummy_layout $i
}
proc layout_quick_input {} {
global wlist
# puts stderr "$wlist \n\r"
.quick_input.i1 configure -width 60
label .quick_input.dummy
pack .quick_input.b.b2 .quick_input.b.b3 -side left -padx 4m -expand 1
pack .quick_input.b -side bottom -pady 4m
pack .quick_input.dummy -side top
pack .quick_input.l0 -side top -expand 1 -ipadx 2m -ipady 2m
pack .quick_input.i1 -side bottom -fill x -padx 4m
}
proc create_drop_target {name icon} {
toplevel .drop-$name
button .drop-$name.b -text "Drop target"
pack .drop-$name.b
wm group .drop-$name .
wm overrideredirect .drop-$name 1
wm withdraw .drop-$name
wm deiconify .drop-$name
wm geometry .drop-$name +0+0
# blt_drag&drop target .drop-$name.b handler file mc_drag_target
# blt_drag&drop target .drop-$name.b handler text mc_drag_target
}
#
# Creates the container
#
proc create_container {container} {
canvas $container
pack $container -fill both -expand 1
}
#
# Removes all of the widgets in a container (.left or .right)
#
proc container_clean {container} {
set widgets [winfo children $container]
foreach widget $widgets {
destroy $widget
}
}
#
# Setups the binding called after the layout procedure
#
proc bind_setup {win} {
flush stderr
bindtags $win {all $win}
wm protocol $win WM_DELETE_WINDOW "tkmc e scape"
bind $win <Leave>
}
proc keyboard_bindings {} {
# Remove the Tab binding.
bind all <Tab> {}
bind all <KeyPress> "tkmc r %A"
# Remove the Alt-key binding and put a sensible one instead
bind all <Alt-KeyPress> "tkmc a %A"
bind all <Control-KeyPress> "tkmc c %A"
bind all <Meta-KeyPress> "tkmc a %A"
foreach i {Left Right Up Down End R13 Home F27 F29 Prior \
Next F35 Return KP_Enter Delete Insert BackSpace \
F1 F2 F3 F4 F5 F6 F7 F8 F9 F10} {
bind all <Key-$i> "tkmc k %K"
}
}
# Centers a window based on .
proc center_win {win} {
global center_toplevels
wm transient $win [winfo toplevel [winfo parent $win]]
wm withdraw $win
update idletasks
if {$center_toplevels} {
set ch [winfo reqheight $win]
set cw [winfo reqwidth $win]
set geo [split [wm geometry .] +x]
set pw [lindex $geo 0]
set ph [lindex $geo 1]
set px [lindex $geo 2]
set py [lindex $geo 3]
set x [expr $px+(($pw-$cw)/2)]
set y [expr $py+(($ph-$ch)/2)]
wm geometry $win +$x+$y
}
wm deiconify $win
grab $win
tkwait visibility $win
}
#
# Busy window handling
#
proc win_busy {w} {
$w configure -cursor watch
}
#
# Color configurations
#
proc tk_colors {} {
}
proc color_model {} {
}
# gray85 is the background for the new tk4
proc gray_colors {base} {
global setup
global have_blt
#
# set setup(def_back) [tkDarken $base 90]
# set setup(def_fore) black
# set setup(selected) [tkDarken $base 110]
# set setup(marked) SlateBlue
# set setup(high) $setup(def_back)
if {0} {
set dark_color [tkDarken $base 90]
set setup(def_back) [tkDarken $base 110]
set setup(selected) NavyBlue
set setup(selected_fg) white
} else {
set dark_color $base
set setup(def_back) #d9d9d9
set setup(selected) white
set setup(selected_fg) black
}
set setup(def_fore) black
set setup(high) yellow
#
# Panel colors:
#
# Marked files
set setup(panelcolor,marked) yellow
set setup(panelcolor,directory) blue
set setup(panelcolor,executable) red
set setup(panelcolor,regular) black
set setup(panelcolor,selected_back) white
set setup(panelcolor,selected) black
# Viewer colors
set setup(view_bold) "-fore yellow -back $dark_color"
set setup(view_underline) "-fore red -back $dark_color"
set setup(view_mark) "-fore cyan -back $dark_color"
set setup(view_normal) "-fore black -back $dark_color"
# The percentage bars on info:
set setup(percolor) "blue"
# The sort bar colors
set setup(sort_fg) $setup(def_fore)
set setup(sort_bg) $setup(def_back)
set setup(with_sortbar) 1
# We use BLT only for drag and drop, if this is not available,
# then we use the 2nd button for regular file marking.
set have_blt 0
if $have_blt {
set setup(b2_marks) 0
} else {
set setup(b2_marks) 1
}
# The errors
set setup(errorfore) white
set setup(errorback) red
}
proc bisque_colors {} {
global setup
set setup(def_back) bisque3
set setup(def_fore) black
set setup(selected) bisque2
set setup(marked) SlateBlue
set setup(high) gray
}
proc sanity_check {} {
if [catch {bindtags .}] {
puts stderr "The Midnight Commander requires Tk 4.0 beta 3 or 4\n\r"
puts stderr "You can get it from: ftp://ftp.smli.com/pub/tcl"
exit 1
}
}
#sanity_check
# Until I figure out how to remove specific bindings from a widget
# I remove all of the classes bindings.
#bind Text <Enter> {}
#bind Text <FocusIn> {}
# bind Entry <Enter> {}
# bind Entry <FocusIn> {}
keyboard_bindings
set setup(tearoff) 0
set setup(action_foreground) blue
set setup(lines) 24
set setup(cols) 40
set setup(with_icons) 0
set setup(widthc) 0
set setup(heightc) 0
set setup(real_width) 0
# Determine Tk version
set beta_4 ![catch tk_bisque]
if $beta_4 {
tk_setPalette gray85
gray_colors gray70
} else {
bisque_colors
}
## Some globals
set mc_repeat {}
set mc_x 0
set mc_y 0
set center_toplevels 1
#set center_toplevels 0
# button .testbutton [lindex [.testbutton configure -font] 3]
#set setup(panelfont) lucidasanstypewriter-bold-14
set setup(panelfont) lucidasanstypewriter-14
set setup(paneldir) lucidasanstypewriter-bold-14
set setup(font) "-*-helvetica-medium-r-normal-*-14-*-*-*-*-*-*-*"
#
#
# This variable if set, will make the program load gui.*.tcl files
# instead of the gui.tcl file created during instalaltion.
set use_separate_gui_files 0
if [file exist ~/.mc/tkmc] {source ~/.mc/tkmc}
catch {
# option add *font $setup(font) userDefault
# option add *Menu*activeBackground NavyBlue
# option add *Menu*activeForeground white
# option add *Menubutton*activeBackground NavyBlue
# option add *Menubutton*activeForeground white
# option add *Button*activeBackground NavyBlue
# option add *Button*activeForeground white
## set setup(panelfont) $setup(font)
}
proc run_gui_design {root} {
global components
create_workspace $root
gui_design $root $components
}
source $LIBDIR/gd.tcl
set tk_strictMotif 1
create_top_menu
create_drop_target Hola Zonzo