Import build of Tcl/Tk 8.6.8
This commit is contained in:
112
amd64/lib/tix8.4.3/demos/samples/STList3.tcl
Normal file
112
amd64/lib/tix8.4.3/demos/samples/STList3.tcl
Normal file
@@ -0,0 +1,112 @@
|
||||
# -*-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
|
||||
}
|
||||
Reference in New Issue
Block a user