You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
113 lines
2.9 KiB
Tcl
113 lines
2.9 KiB
Tcl
3 weeks ago
|
# -*-mode: tcl; fill-column: 75; tab-width: 8; coding: iso-latin-1-unix -*-
|
||
|
#
|
||
|
# $Id: STList3.tcl,v 1.4 2004/03/28 02:44:56 hobbs Exp $
|
||
|
#
|
||
|
# Tix Demostration Program
|
||
|
#
|
||
|
# This sample program is structured in such a way so that it can be
|
||
|
# executed from the Tix demo program "widget": it must have a
|
||
|
# procedure called "RunSample". It should also have the "if" statment
|
||
|
# at the end of this file so that it can be run as a standalone
|
||
|
# program using tixwish.
|
||
|
|
||
|
# Demonstrates the use of DirTree with the TList
|
||
|
#
|
||
|
|
||
|
proc RunSample {w} {
|
||
|
set top [frame $w.f -bd 1 -relief raised]
|
||
|
set box [tixButtonBox $w.b -bd 1 -relief raised]
|
||
|
|
||
|
pack $box -side bottom -fill both
|
||
|
pack $top -side top -fill both -expand yes
|
||
|
|
||
|
# Create the Paned Window to contain the dirtree and scrolled tlist
|
||
|
#
|
||
|
set p [tixPanedWindow $top.p -orient horizontal]
|
||
|
pack $p -expand yes -fill both -padx 4 -pady 4
|
||
|
|
||
|
set p1 [$p add pane1 -expand 1]
|
||
|
set p2 [$p add pane2 -expand 4]
|
||
|
|
||
|
$p1 config -relief flat
|
||
|
$p2 config -relief flat
|
||
|
|
||
|
# Create a DirTree
|
||
|
#
|
||
|
tixDirTree $p1.dirtree -options {
|
||
|
hlist.width 28
|
||
|
}
|
||
|
|
||
|
pack $p1.dirtree -expand yes -fill both -padx 4 -pady 4
|
||
|
|
||
|
|
||
|
# Create a TList
|
||
|
# NOTE: we set the width of the tlist to 60 characters, since we'll have
|
||
|
# quite a few files to display
|
||
|
#
|
||
|
tixScrolledTList $p2.st -options {
|
||
|
tlist.orient vertical
|
||
|
tlist.selectMode single
|
||
|
tlist.width 60
|
||
|
tlist.height 25
|
||
|
}
|
||
|
pack $p2.st -expand yes -fill both -padx 4 -pady 4
|
||
|
|
||
|
set tlist [$p2.st subwidget tlist]
|
||
|
|
||
|
# setup the callbacks: when the user selects a directory, we'll display
|
||
|
# its content in the tlist widget
|
||
|
$p1.dirtree config \
|
||
|
-browsecmd [list TList:listdir $tlist] \
|
||
|
-command [list TList:listdir $tlist]
|
||
|
|
||
|
# List the directory now
|
||
|
#
|
||
|
TList:listdir $tlist [pwd]
|
||
|
|
||
|
# Create the buttons
|
||
|
#
|
||
|
$box add ok -text Ok -command [list destroy $w] -width 6
|
||
|
$box add cancel -text Cancel -command [list destroy $w] -width 6
|
||
|
}
|
||
|
|
||
|
proc TList:listdir {w dir} {
|
||
|
$w delete 0 end
|
||
|
|
||
|
if {[catch {glob -nocomplain -directory $dir *} entries]} {
|
||
|
# The user has entered an invalid directory
|
||
|
# %% todo: prompt error, go back to last succeed directory
|
||
|
return
|
||
|
}
|
||
|
|
||
|
set files ""
|
||
|
foreach fname [lsort -dictionary $entries] {
|
||
|
if {[file isdirectory $fname]} {
|
||
|
set image [tix getimage folder]
|
||
|
} else {
|
||
|
lappend files [file tail $fname]
|
||
|
continue
|
||
|
}
|
||
|
$w insert end -itemtype imagetext \
|
||
|
-text [file tail $fname] -image $image
|
||
|
}
|
||
|
|
||
|
foreach fname $files {
|
||
|
switch -glob -- $fname {
|
||
|
{*.[ch]} { set image [tix getimage srcfile] }
|
||
|
*.tcl -
|
||
|
*.o { set image [tix getimage file] }
|
||
|
default { set image [tix getimage textfile] }
|
||
|
}
|
||
|
$w insert end -itemtype imagetext -text $fname -image $image
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
if {![info exists tix_demo_running]} {
|
||
|
wm withdraw .
|
||
|
set w .demo
|
||
|
toplevel $w; wm transient $w ""
|
||
|
RunSample $w
|
||
|
bind $w <Destroy> exit
|
||
|
}
|