X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=client.tcl;h=2403c2e634ce641c1fb5720bd286f88fd698f1d9;hb=d026c3e06f6e19e5ed4174ab1a504a4b5af79183;hp=fbf9401b6a4cd0ae4beff3185b048be9233dea72;hpb=f28f018de9b648bf36af3de63c942cc3bcb53b6e;p=ir-tcl-moved-to-github.git diff --git a/client.tcl b/client.tcl index fbf9401..2403c2e 100644 --- a/client.tcl +++ b/client.tcl @@ -1,10 +1,66 @@ # IR toolkit for tcl/tk -# (c) Index Data 1995 +# (c) Index Data 1995-2001 # See the file LICENSE for details. # Sebastian Hammer, Adam Dickmeiss # # $Log: client.tcl,v $ -# Revision 1.93 1996-06-28 08:43:54 adam +# Revision 1.111 2001-12-03 18:52:06 adam +# Configure no longer searches for Tk. Removed references to SR. +# +# Revision 1.110 2000/10/11 12:26:47 adam +# Using yaz.m4 for aclocal.m4. +# +# Revision 1.109 1999/12/12 00:25:59 adam +# Updated list of preconfigure targets. +# +# Revision 1.108 1999/11/30 14:05:58 adam +# Updated for new location of YAZ headers. +# +# Revision 1.107 1999/02/11 11:30:08 adam +# Updated for WIN32. +# +# Revision 1.106 1998/06/10 13:22:47 adam +# Minor changes. +# +# Revision 1.105 1998/06/10 13:00:45 adam +# Added ir-version command. +# +# Revision 1.104 1998/02/12 13:32:41 adam +# Updated configuration system. +# +# Revision 1.103 1998/01/30 13:30:50 adam +# Name of target database is irtdb.tcl instead of clientrc.tcl. +# +# Revision 1.102 1997/11/19 13:19:54 adam +# Font fix. +# +# Revision 1.101 1997/11/19 11:20:56 adam +# New target profile format - associative arrrays instead of LONG lists. +# +# Revision 1.100 1997/09/09 10:19:50 adam +# New MSV5.0 port with fewer warnings. +# +# Revision 1.99 1997/04/13 19:00:37 adam +# Added support for Tcl8.0/Tk8.0. +# New command ir-log-init to setup yaz logging facilities. +# +# Revision 1.98 1996/11/14 17:11:04 adam +# Added Explain documentaion. +# +# Revision 1.97 1996/09/13 10:54:22 adam +# Started work on Explain in client. +# +# Revision 1.96 1996/08/09 15:30:18 adam +# Procedure destroyGW modified to handle multiple calls - probably an +# error introduced by tk4.1 patch level 1. +# +# Revision 1.95 1996/07/26 09:15:08 adam +# IrTcl version 1.2 patch level 1. +# +# Revision 1.94 1996/07/25 15:55:34 adam +# IrTcl version 1.2 release. +# +# Revision 1.93 1996/06/28 08:43:54 adam # Moved towards version 1.2. # # Revision 1.92 1996/03/29 16:04:30 adam @@ -321,6 +377,7 @@ # # + # Procedure tk4 is defined - returns 0 if tk 3.6 - returns 1 otherwise if {$tk_version == "3.6"} { proc tk4 {} { @@ -332,9 +389,20 @@ if {$tk_version == "3.6"} { } } -# The following two procedures deals with menu entries. The interface +# The following procedures deals with menu entries. The interface # changed from Tk 3.6 to 4.X +# Procedure irmenu +if {[tk4]} { + proc irmenu {w} { + menu $w -tearoff off + } +} else { + proc irmenu {w} { + menu $w + } +} + # Procedure configure-enable-e {w n} # w is a menu # n menu entry number (0 is first entry) @@ -347,11 +415,11 @@ if {$tk_version == "3.6"} { if {[tk4]} { proc configure-enable-e {w n} { - incr n +# incr n $w entryconfigure $n -state normal } proc configure-disable-e {w n} { - incr n +# incr n $w entryconfigure $n -state disabled } set noFocus [list -takefocus 0] @@ -365,6 +433,12 @@ if {[tk4]} { set noFocus {} } +# Define dummy clock function if it is not there. +if {[catch {clock seconds}]} { + proc clock {args} { + return {} + } +} # Set monoFlag to 1 if screen is known not to support colors; otherwise # set monoFlag to 0 if {![tk4]} { @@ -401,7 +475,33 @@ set hotTargets {} set hotInfo {} set busy 0 -set profile(Default) {{} {} {210} {} 50000 30000 tcpip {} 1 {} {} Z39 1 2 0 0 4} +set profile(Default,description) {} +set profile(Default,host) {} +set profile(Default,port) 210 +set profile(Default,authentication) {} +set profile(Default,maximumRecordSize) 50000 +set profile(Default,preferredMessageSize) 30000 +set profile(Default,comstack) tcpip +set profile(Default,namedResultSets) 1 +set profile(Default,queryRPN) 1 +set profile(Default,queryCCL) 0 +set profile(Default,protocol) Z39 +set profile(Default,windowNumber) 1 +set profile(Default,largeSetLowerBound) 2 +set profile(Default,smallSetUpperBound) 0 +set profile(Default,mediumSetPresentNumber) 0 +set profile(Default,presentChunk) 4 +set profile(Default,timeDefine) {} +set profile(Default,timeLastInit) {} +set profile(Default,timeLastExplain) {} +set profile(Default,targetInfoName) {} +set profile(Default,recentNews) {} +set profile(Default,maxResultSets) {} +set profile(Default,maxResultSize) {} +set profile(Default,maxTerms) {} +set profile(Default,multipleDatabases) 0 +set profile(Default,welcomeMessage) {} + set hostid Default set settingsChanged 0 set setNo 0 @@ -418,46 +518,70 @@ set debugMode 0 set queryTypes {Simple} set queryButtons { { {I 0} {I 1} {I 2} } } -set queryInfo { { {Title {1=4 4=1}} {Author {1=1}} \ - {Subject {1=21}} {Any {1=1016}} } } +set queryInfo {{{Title {1=4}} {Author {1=1003}} \ + {Subject {1=21}} {Any {1=1016}} {Abstract {1=62}}}} wm minsize . 0 0 set setOffset 0 set setMax 0 +if {[lindex [split $tk_version .] 0] < 5} { + set font(bb,normal) -Adobe-Helvetica-Medium-R-Normal-*-240-* + set font(bb,bold) -Adobe-Helvetica-Bold-R-Normal-*-240-* + set font(b,normal) -Adobe-Helvetica-Medium-R-Normal-*-180-* + set font(b,bold) -Adobe-Helvetica-Bold-R-Normal-*-180-* + set font(n,normal) -Adobe-Helvetica-Medium-R-Normal-*-120-* + set font(n,bold) -Adobe-Helvetica-Bold-R-Normal-*-120-* + set font(s,bold) -Adobe-Helvetica-Bold-R-Normal-*-100-* + set font(ss,bold) -Adobe-Helvetica-Bold-R-Normal-*-80-* +} else { + set font(bb,normal) {Helvetica 24} + set font(bb,bold) {Helvetica 24 bold} + set font(b,normal) {Helvetica 24} + set font(b,bold) {Helvetica 18 bold} + set font(n,normal) {Helvetica 12} + set font(n,bold) {Helvetica 12 bold} + set font(s,bold) {Helvetica 10 bold} + set font(ss,bold) {Helvetica 8 bold} +} + # Procedure tkerror {err} # err error message # Override the Tk error handler function. -proc tkerror err { - set w .tkerrorw - - if {[winfo exists $w]} { - destroy $w +if {1} { + proc tkerror err { + global font + set w .tkerrorw + + if {[winfo exists $w]} { + destroy $w + } + toplevel $w + wm title $w "Error" + + place-force $w . + top-down-window $w + + label $w.top.b -bitmap error + message $w.top.t -aspect 300 -text "Error: $err" \ + -font $font(b,bold) + pack $w.top.b $w.top.t -side left -padx 10 -pady 10 + + bottom-buttons $w [list {Close} [list destroy $w]] 1 } - toplevel $w - wm title $w "Error" - - place-force $w . - top-down-window $w - - label $w.top.b -bitmap error - message $w.top.t -aspect 300 -text "Error: $err" \ - -font -Adobe-Helvetica-Bold-R-Normal-*-180-* - pack $w.top.b $w.top.t -side left -padx 10 -pady 10 - - bottom-buttons $w [list {Close} [list destroy $w]] 1 } - # Read tag set file (if present) if {[file readable "${libdir}/tagsets.tcl"]} { source "${libdir}/tagsets.tcl" } -# Read the global configuration file. -if {[file readable "clientrc.tcl"]} { - source "clientrc.tcl" -} elseif {[file readable "${libdir}/clientrc.tcl"]} { - source "${libdir}/clientrc.tcl" +# Read the global target configuration file. +if {[file readable "${libdir}/irtdb.tcl"]} { + source "${libdir}/irtdb.tcl" +} +# Read the local target configuration file. +if {[file readable "irtdb.tcl"]} { + source "irtdb.tcl" } # Read the user configuration file. @@ -465,6 +589,39 @@ if {[file readable "~/.clientrc.tcl"]} { source "~/.clientrc.tcl" } +# Convert old format to new format... +foreach target [array names profile] { + set timedef [clock seconds] + if {[string first , $target] == -1} { + if {![info exists profile($target,port)]} { + foreach n [array names profile Default,*] { + set profile($target,[string range $n 8 end]) $profile($n) + } + set profile($target,description) [lindex $profile($target) 0] + set profile($target,host) [lindex $profile($target) 1] + set profile($target,port) [lindex $profile($target) 2] + set profile($target,authentication) [lindex $profile($target) 3] + set profile($target,maximumRecordSize) \ + [lindex $profile($target) 4] + set profile($target,preferredMessageSize) \ + [lindex $profile($target) 5] + set profile($target,comstack) [lindex $profile($target) 6] + set profile($target,databases) [lindex $profile($target) 7] + set profile($target,timeDefine) $timedef + set profile($target,windowNumber) 1 + } + unset profile($target) + } +} + +# Assign unique ID's to each target's window number +set wno 1 +foreach n [array names profile *,windowNumber] { + set profile($n) $wno + incr wno +} +set profile(Default,windowNumber) $wno + # These globals describe the current query type. They are set to the # first query type. set queryButtonsFind [lindex $queryButtons 0] @@ -535,7 +692,8 @@ proc apduDump {} { top-down-window $w text $w.top.t -font fixed -width 60 -height 12 -wrap word \ - -relief flat -borderwidth 0 -yscrollcommand [list $w.top.s set] + -relief flat -borderwidth 0 \ + -yscrollcommand [list $w.top.s set] -background grey85 scrollbar $w.top.s -command [list $w.top.t yview] pack $w.top.s -side right -fill y @@ -556,9 +714,7 @@ proc apduDump {} { # f display format # Reformats main record window to use display format given by f proc set-display-format {f} { - global displayFormat - global setNo - global busy + global displayFormat setNo busy set displayFormat $f if {$setNo == 0} { @@ -574,23 +730,12 @@ proc set-display-format {f} { # Procedure initBindings # Disables various default bindings for Text and Listbox widgets. proc initBindings {} { - set w Text - bind $w <1> {} - bind $w {} - bind $w {} - bind $w {} - bind $w {} - bind $w {} - bind $w <2> {} - bind $w {} - bind $w {} - bind $w {} - bind $w {} - bind $w {} - bind $w {} - bind $w {} - bind $w {} + global TextBinding + foreach e [bind Text] { + set TextBinding($e) [bind Text $e] + bind Text $e {} + } set w Listbox bind $w {} bind $w {} @@ -598,6 +743,16 @@ proc initBindings {} { set w Entry } +# Procedure TextEditable +# Apply "standard" events to a text widget. It should be editable now. +proc TextEditable {w} { + global TextBinding + + foreach e [array names TextBinding] { + bind $w $e $TextBinding($e) + } +} + # Procedure post-menu {wbutton wmenu} # wbutton button widget # wmenu menu widget @@ -610,6 +765,21 @@ proc post-menu {wbutton wmenu} { } +# Procedure place-force {window parent} +# window new top level widget +# parent parent widget used as base +# Sets geometry of $window relative to $parent window. +proc place-force {window parent} { + set g [wm geometry $parent] + + set p1 [string first + $g] + set p2 [string last + $g] + + set x [expr 40+[string range $g [expr $p1 +1] [expr $p2 -1]]] + set y [expr 60+[string range $g [expr $p2 +1] end]] + wm geometry $window +${x}+${y} +} + # Procedure destroyGW {w} # w top level widget # Saves geometry of widget w in windowGeometry array. This @@ -618,7 +788,7 @@ proc post-menu {wbutton wmenu} { # See also topLevelG. proc destroyGW {w} { global windowGeometry - set windowGeometry($w) [wm geometry $w] + catch {set windowGeometry($w) [wm geometry $w]} } # Procedure topLevelG @@ -632,7 +802,7 @@ proc toplevelG {w} { toplevel $w if {[info exists windowGeometry($w)]} { set g $windowGeometry($w) - if {$g != ""} { + if {[string length $g]} { wm geometry $w $g } } @@ -650,6 +820,14 @@ proc top-down-window {w} { pack $w.bot -fill both } +# Init: The geometry information for the main window is set - either +# to a default value or to the value in windowGeometry(.) +if {[catch {set g $windowGeometry(.)}]} { + wm geometry . 420x340+20+20 +} else { + wm geometry . $g +} + # Procedure top-down-ok-cancel {w ok-action g} # w top level widget with $w.bot-frame # ok-action ok script @@ -712,11 +890,9 @@ proc bottom-buttons {w buttonList g} { # If the system is currently busy a "Cancel" will be displayed in the # status area and the cancelFlag is set to true indicating that future # responses from the target should be ignored. The system is no longer -# when this procedure exists. +# busy when this procedure exists. proc cancel-operation {} { - global cancelFlag - global busy - global delayRequest + global cancelFlag busy delayRequest if {$busy} { set cancelFlag 1 @@ -730,13 +906,11 @@ proc cancel-operation {} { # base name of database # Displays target name and database name in the target status area. proc show-target {target base} { - global profile - - if {$target == ""} { - .bot.a.target configure -text "" + if {![string length $target]} { + .bot.a.target configure -text {} return } - if {$base == ""} { + if {![string length $base]} { .bot.a.target configure -text "$target" } else { .bot.a.target configure -text "$target - $base" @@ -750,8 +924,7 @@ proc show-target {target base} { # by itself. The global 'busy' variable determines whether the logo is # moving or not. proc show-logo {v1} { - global busy - global libdir + global busy libdir if {$busy != 0} { incr v1 @@ -780,11 +953,8 @@ proc show-logo {v1} { # busy flag 'busy' to b if b is non-empty. If sb is non-empty it indicates # whether service buttons should be enabled or disabled. proc show-status {status b sb} { - global busy - global scanEnable - global setOffset - global setMax - global setNo + global busy scanEnable + global setOffset setMax setNo .bot.a.status configure -text "$status" if {$b == 1} { @@ -800,6 +970,8 @@ proc show-status {status b sb} { .mid.search configure -state normal if {$scanEnable} { .mid.scan configure -state normal + } else { + configure-disable-e .top.service.m 3 } if {$setNo == 0} { configure-disable-e .top.service.m 1 @@ -888,7 +1060,7 @@ proc popup-license {} { # as implementation-name, implementation-id, etc. proc about-target {} { set w .about-target-w - global hostid + global hostid font toplevel $w @@ -902,8 +1074,7 @@ proc about-target {} { pack $w.top.a $w.top.p -side top -fill x label $w.top.a.about -text "About" - label $w.top.a.irtcl -text $hostid \ - -font -Adobe-Helvetica-Bold-R-Normal-*-240-* + label $w.top.a.irtcl -text $hostid -font $font(bb,bold) pack $w.top.a.about $w.top.a.irtcl -side top set i [z39 targetImplementationName] @@ -941,8 +1112,7 @@ proc about-origin-logo {n} { # Display various information about origin (this client). proc about-origin {} { set w .about-origin-w - global libdir - global tk_version + global libdir font tk_version if {[winfo exists $w]} { destroy $w @@ -958,22 +1128,16 @@ proc about-origin {} { pack $w.top.a $w.top.p -side top -fill x - label $w.top.a.irtcl -text "IrTcl" \ - -font -Adobe-Helvetica-Bold-R-Normal-*-240-* + label $w.top.a.irtcl -text "IrTcl" -font $font(bb,bold) label $w.top.a.logo -bitmap @${libdir}/bitmaps/book1 pack $w.top.a.irtcl $w.top.a.logo -side left -expand yes - set i unknown - catch {set i [z39 implementationName]} - label $w.top.p.in -text "Implementation name: $i" - catch {set i [z39 implementationId]} - label $w.top.p.ii -text "Implementation id: $i" - catch {set i [z39 implementationVersion]} - label $w.top.p.iv -text "Implementation version: $i" - set i $tk_version - label $w.top.p.tk -text "Tk version: $i" + label $w.top.p.irtcl -text "IrTcl version: [lindex [ir-version] 0]" + label $w.top.p.yaz -text "Yaz version: [lindex [ir-version] 1]" - pack $w.top.p.in $w.top.p.ii $w.top.p.iv $w.top.p.tk -side top -anchor nw + label $w.top.p.tk -text "Tk version: $tk_version" + + pack $w.top.p.irtcl $w.top.p.yaz $w.top.p.tk -side top -anchor nw about-origin-logo 1 bottom-buttons $w [list {Close} [list destroy $w] \ @@ -988,8 +1152,7 @@ proc about-origin {} { # Displays record in set $sno at position $no in window .full-marc$b. # The global variable $popupMarcdf holds the current format method. proc popup-marc {sno no b df} { - global displayFormats - global popupMarcdf + global font displayFormats popupMarcdf if {[z39.$sno type $no] != "DB"} { return @@ -1014,7 +1177,8 @@ proc popup-marc {sno no b df} { pack $w.bot -fill both text $w.top.record -width 60 -height 5 -wrap word -relief flat \ - -borderwidth 0 -font fixed -yscrollcommand [list $w.top.s set] + -borderwidth 0 -font fixed \ + -yscrollcommand [list $w.top.s set] -background grey85 scrollbar $w.top.s -command [list $w.top.record yview] global monoFlag @@ -1026,18 +1190,14 @@ proc popup-marc {sno no b df} { $w.top.record tag configure marc-id -foreground black } $w.top.record tag configure marc-data -foreground black - $w.top.record tag configure marc-head \ - -font -Adobe-Times-Medium-R-Normal-*-180-* \ + $w.top.record tag configure marc-head -font $font(n,bold) \ -background black -foreground white - $w.top.record tag configure marc-pref \ - -font -Adobe-Times-Medium-R-Normal-*-180-* \ + $w.top.record tag configure marc-pref -font $font(n,normal) \ -foreground blue - $w.top.record tag configure marc-text \ - -font -Adobe-Times-Medium-R-Normal-*-180-* \ + $w.top.record tag configure marc-text -font $font(n,normal) \ -foreground black - $w.top.record tag configure marc-it \ - -font -Adobe-Times-Medium-I-Normal-*-180-* \ + $w.top.record tag configure marc-it -font $font(n,normal) \ -foreground black pack $w.top.s -side right -fill y @@ -1050,7 +1210,7 @@ proc popup-marc {sno no b df} { {Duplicate} {}] 0 menubutton $w.bot.formats -text "Format" -menu $w.bot.formats.m \ -relief raised - menu $w.bot.formats.m + irmenu $w.bot.formats.m pack $w.bot.formats -expand yes -ipadx 2 -ipady 2 \ -padx 3 -pady 3 -side left } else { @@ -1137,7 +1297,7 @@ proc set-target-hotlist {olen} { if {$olen > 0} { if {[tk4]} { - .top.target.m delete 7 [expr 7+$olen] + .top.target.m delete 6 [expr 6+$olen] } else { .top.target.m delete 6 [expr 6+$olen] } @@ -1146,7 +1306,7 @@ proc set-target-hotlist {olen} { foreach e $hotTargets { set target [lindex $e 0] set base [lindex $e 1] - if {$base == ""} { + if {![string length $base]} { .top.target.m add command -label "$i $target" -command \ [list reopen-target $target {}] } else { @@ -1180,22 +1340,22 @@ proc define-target-action {} { global profile set target [.target-define.top.target.entry get] - if {$target == ""} { + if {![string length $target]} { return } - foreach n [array names profile] { - if {$n == $target} { + foreach n [array names profile *,host] { + if {![string compare $n ${target},host]} { destroy .target-define protocol-setup $n return } } - set seq [lindex $profile(Default) 12] - dputs "seq=${seq}" - dputs $profile(Default) - set profile($target) $profile(Default) - set profile(Default) [lreplace $profile(Default) 12 12 [incr seq]] - + foreach n [array names profile Default,*] { + set profile($target,[string range $n 8 end]) $profile($n) + + } + incr profile(Default,windowNumber) + protocol-setup $target destroy .target-define } @@ -1223,8 +1383,7 @@ proc fail-response {target} { # IrTcl connect response handler. proc connect-response {target base} { dputs "connect-response" - show-target $target $base - init-request + init-request $target $base } # Procedure open-target {target base} @@ -1237,53 +1396,49 @@ proc open-target {target base} { global presentChunk z39 disconnect - z39 comstack [lindex $profile($target) 6] - z39 protocol [lindex $profile($target) 11] - z39 idAuthentication [lindex $profile($target) 3] - z39 maximumRecordSize [lindex $profile($target) 4] - z39 preferredMessageSize [lindex $profile($target) 5] - dputs "maximumRecordSize=" - dputs [z39 maximumRecordSize] - dputs "preferredMessageSize=" - dputs [z39 preferredMessageSize] + z39 comstack $profile($target,comstack) + z39 protocol $profile($target,protocol) + eval z39 idAuthentication $profile($target,authentication) + z39 maximumRecordSize $profile($target,maximumRecordSize) + z39 preferredMessageSize $profile($target,preferredMessageSize) + dputs "maximumRecordSize=[z39 maximumRecordSize]" + dputs "preferredMessageSize=[z39 preferredMessageSize]" show-status Connecting 1 0 - if {$base == ""} { - z39 databaseNames [lindex [lindex $profile($target) 7] 0] - } else { - z39 databaseNames $base - } - set x [lindex $profile($target) 13] - if {$x == ""} { + set x $profile($target,largeSetLowerBound) + if {![string length $x]} { set x 2 } z39 largeSetLowerBound $x - - set x [lindex $profile($target) 14] - if {$x == ""} { + + set x $profile($target,smallSetUpperBound) + if {![string length $x]} { set x 0 } z39 smallSetUpperBound $x - - set x [lindex $profile($target) 15] - if {$x == ""} { + + set x $profile($target,mediumSetPresentNumber) + if {![string length $x]} { set x 0 } z39 mediumSetPresentNumber $x - set presentChunk [lindex $profile($target) 16] - if {$presentChunk == ""} { + set presentChunk $profile($target,presentChunk) + if {![string length $presentChunk]} { set presentChunk 4 } z39 failback [list fail-response $target] z39 callback [list connect-response $target $base] + show-target $target $base update idletasks set err [catch { - z39 connect [lindex $profile($target) 1]:[lindex $profile($target) 2] + z39 connect $profile($target,host):$profile($target,port) } errorMessage] if {$err} { + set hostid Default tkerror $errorMessage show-status "Not connected" 0 {} + show-target {} {} return } set hostid $target @@ -1313,7 +1468,7 @@ proc close-target {} { configure-disable-e .top.target.m 1 configure-disable-e .top.target.m 2 if {[tk4]} { - .top.rset.m delete 2 last + .top.rset.m delete 1 last } else { .top.rset.m delete 1 last } @@ -1370,14 +1525,14 @@ proc load-set {} { # Procedure init-request # Sends an initialize request to the target. This procedure is called # when a connect has been established. -proc init-request {} { +proc init-request {target base} { global cancelFlag if {$cancelFlag} { close-target return } - z39 callback {init-response} + z39 callback [list init-response $target $base] show-status Initializing 1 {} set err [catch {z39 init} errorMessage] if {$err} { @@ -1390,31 +1545,82 @@ proc init-request {} { # Handles and incoming init-response. The service buttons # are enabled. The global $scanEnable indicates whether the target # supports scan. -proc init-response {} { - global cancelFlag - global scanEnable +proc init-response {target base} { + global cancelFlag profile scanEnable settingsChanged - dputs {init-reponse} + dputs {init-response} apduDump if {$cancelFlag} { close-target return } if {![z39 initResult]} { - show-status Ready 0 1 set u [z39 userInformationField] close-target tkerror "Connection rejected by target: $u" } else { - if {[lsearch [z39 options] scan] >= 0} { - set scanEnable 1 - } else { - set scanEnable 0 - } - show-status Ready 0 1 + z39 failback [list explain-crash $target $base] + explain-check $target [list ready-response $base] } } +# Procedure explain-crash +# Handles target that dies during explain. +proc explain-crash {target base} { + global profile settingsChanged + + set profile($target,timeLastInit) [clock seconds] + set profile($target,timeLastExplain) {} + set settingsChanged 1 + + show-message {} + open-target $target $base +} + +# Procedure explain-check +# Stub function to check explain. May be overwritten later. +proc explain-check {target response} { + eval $response [list $target] +} + +# Procedure ready-response +# Called after a target has been initialized and, possibly, explained +proc ready-response {base target} { + global profile settingsChanged scanEnable + + z39 failback [list fail-response $target] + if {[string length $base]} { + set profile($target,timeLastInit) [clock seconds] + set settingsChanged 1 + + z39 databaseNames $base + cascade-dblist $target $base + show-target $target $base + } + if {[lsearch [z39 options] scan] >= 0} { + set scanEnable 1 + } else { + set scanEnable 0 + } + .data.record delete 1.0 end + set desc [string trim $profile($target,description)] + if {[string length $desc]} { + .data.record insert end "$desc\n\n" + } else { + .data.record insert end "$target\n\n" + } + set data [string trim $profile($target,welcomeMessage)] + if {[string length $data]} { + .data.record insert end "Welcome Message:\n$data\n\n" + } + set data [string trim $profile($target,recentNews)] + if {[string length $data]} { + .data.record insert end "News:\n$data\n" + } + show-message {} + show-status Ready 0 1 +} + # Procedure search-request # bflag flag to indicate if this procedure calls itself # Performs a search. If $busy is 1, the search-request is performed @@ -1433,8 +1639,8 @@ proc search-request {bflag} { global elementSetNames set target $hostid - - if {[z39 connect] == ""} { + + if {![string length [z39 connect]]} { return } dputs "search-request" @@ -1452,34 +1658,33 @@ proc search-request {bflag} { set delayRequest {} set query [index-query] - if {$query==""} { + if {![string length $query]} { return } incr setNoLast set setNo $setNoLast ir-set z39.$setNo z39 - - if {[lindex $profile($target) 10] == 1} { + + if {$profile($target,namedResultSets)} { z39.$setNo setName $setNo dputs "setName=${setNo}" } else { - z39.$setNo setName Default - dputs "setName=Default" - } - if {[lindex $profile($target) 8] == 1} { - z39.$setNo queryType rpn + z39.$setNo setName default + dputs "setName=default" } - if {[lindex $profile($target) 9] == 1} { - z39.$setNo queryType ccl + if {$profile($target,queryRPN)} { + z39.$setNo queryType rpn + } elseif {$profile($target,queryCCL)} { + z39.$setNo queryType ccl } dputs Setting dputs $recordSyntax - if {$recordSyntax == "None" } { + if {![string compare $recordSyntax None]} { z39.$setNo preferredRecordSyntax {} } else { z39.$setNo preferredRecordSyntax $recordSyntax } - if {$elementSetNames == "None" } { + if {![string compare $elementSetNames None]} { z39.$setNo elementSetNames {} z39.$setNo smallSetElementSetNames {} z39.$setNo mediumSetElementSetNames {} @@ -1600,7 +1805,7 @@ proc scan-term-h {attr} { z39.scan numberOfTermsRequested 5 z39.scan preferredPositionInResponse 1 dputs "${attr} \{${scanTerm}\}" - if {$scanTerm == ""} { + if {![string length $scanTerm]} { z39.scan scan "${attr} 0" } else { z39.scan scan "${attr} \{${scanTerm}\}" @@ -1652,7 +1857,7 @@ proc scan-response {attr start toget} { z39.scan preferredPositionInResponse 1 set scanTerm $nScanTerm dputs "${attr} \{${scanTerm}\}" - if {$scanTerm == ""} { + if {![string length $scanTerm]} { z39.scan scan "${attr} 0" } else { z39.scan scan "${attr} \{${scanTerm}\}" @@ -1800,7 +2005,7 @@ proc scan-up {attr} { # Procedure search-response # This procedure handles search-responses. If the search is successful -# this procedure will try to retrieve a total of 20 records from the target; +# this procedure will try to retrieve a total of 50 records from the target; # however not more than $presentChunk records at a time. This procedure # affects the following globals: # $setOffset current record position offset @@ -1830,7 +2035,7 @@ proc search-response {} { set setMax [z39.$setNo resultCount] show-status Ready 0 1 set status [z39.$setNo responseStatus] - if {[lindex $status 0] == "NSD"} { + if {![string compare [lindex $status 0] NSD]} { z39.$setNo nextResultSetPosition 0 set code [lindex $status 1] set msg [lindex $status 2] @@ -1847,8 +2052,8 @@ proc search-response {} { set l [format "%-4d %7d" $setNo $setMax] .top.rset.m add command -label $l \ -command [list recall-set $setNo] - if {$setMax > 20} { - set setMax 20 + if {$setMax > 50} { + set setMax 50 } set no [z39.$setNo numberOfRecordsReturned] dputs "Returned $no records, setOffset $setOffset" @@ -1906,7 +2111,7 @@ proc present-more {number} { show-status Ready 0 1 return } - if {$number == ""} { + if {![string length $number]} { set setMax $max } else { incr setMax $number @@ -1915,7 +2120,7 @@ proc present-more {number} { } } z39 callback {present-response} - + set toGet [expr $setMax - $setOffset + 1] if {$toGet <= 0} { return @@ -1930,7 +2135,7 @@ proc present-more {number} { # Procedure init-title-lines # Utility that cleans the main record window. proc init-title-lines {} { - .data.record delete 0.0 end + .data.record delete 1.0 end } # Procedure recall-set {setno} @@ -1960,7 +2165,7 @@ proc add-title-lines {setno no offset} { } if {$offset == 1} { .bot.a.set configure -text $setno - .data.record delete 0.0 end + .data.record delete 1.0 end } set ffunc [lindex $displayFormats $displayFormat] dputs "ffunc=$ffunc" @@ -1968,7 +2173,7 @@ proc add-title-lines {setno no offset} { for {set i 0} {$i < $no} {incr i} { set o [expr $i + $offset] set type [z39.$setno type $o] - if {$type == ""} { + if {![string length $type]} { dputs "no more at $o" break } @@ -2013,7 +2218,7 @@ proc present-response {} { return } set status [z39.$setNo responseStatus] - if {[lindex $status 0] == "NSD"} { + if {![string compare [lindex $status 0] NSD]} { show-status Ready 0 1 set code [lindex $status 1] set msg [lindex $status 2] @@ -2128,14 +2333,15 @@ proc define-target-dialog {} { # This procedure is invoked when the user tries to delete a target # definition. If user is sure, the target definition is deleted. proc protocol-setup-delete {target w} { - global profile - global settingsChanged + global profile settingsChanged set a [alert "Are you sure you want to delete the target \ definition $target ?"] if {$a} { destroy $w - unset profile($target) + foreach n [array names profile $target,*] { + unset profile($n) + } set settingsChanged 1 cascade-target-list delete-target-hotlist $target @@ -2146,60 +2352,37 @@ definition $target ?"] # target target to be defined # w target definition toplevel widget # This procedure reads all appropriate globals and makes a new/modified -# profile for the target. The global array $targetS contains most of the +# profile for the target. The global array $profileS contains most of the # information the user may modify. proc protocol-setup-action {target w} { - global profile - global settingsChanged - global targetS + global profile settingsChanged profileS set dataBases {} set settingsChanged 1 + + puts "protocol-setup-action" + set timedef $profile($target,timeDefine) + if {![string length $timedef]} { + set timedef [clock seconds] + } + set profileS($target,timeDefine) $timedef + + foreach n [array names profile $target,*] { + set profile($n) $profileS($n) + unset profileS($n) + } + set len [$w.top.databases.list size] + catch {unset profile($target,databases)} for {set i 0} {$i < $len} {incr i} { - lappend dataBases [$w.top.databases.list get $i] - } - set wno [lindex $profile($target) 12] - - set profile($target) [list [$w.top.description.entry get] \ - [$w.top.host.entry get] \ - [$w.top.port.entry get] \ - [$w.top.idAuthentication.entry get] \ - $targetS($target,MRS) \ - $targetS($target,PMS) \ - $targetS($target,csType) \ - $dataBases \ - $targetS($target,RPN) \ - $targetS($target,CCL) \ - $targetS($target,ResultSets) \ - $targetS($target,protocolType) \ - $wno \ - $targetS($target,LSLB) \ - $targetS($target,SSUB) \ - $targetS($target,MSPN) \ - $targetS($target,presentChunk) ] + lappend profile($target,databases) [$w.top.databases.list get $i] + } cascade-target-list delete-target-hotlist $target - dputs $profile($target) destroy $w } -# Procedure place-force {window parent} -# window new top level widget -# parent parent widget used as base -# Sets geometry of $window relative to $parent window. -proc place-force {window parent} { - set g [wm geometry $parent] - - set p1 [string first + $g] - set p2 [string last + $g] - - set x [expr 40+[string range $g [expr $p1 +1] [expr $p2 -1]]] - set y [expr 60+[string range $g [expr $p2 +1] end]] - wm geometry $window +${x}+${y} -} - # Procedure add-database-action {target w} # target target to be defined # w top level widget for the target definition @@ -2240,6 +2423,7 @@ proc add-database {target wp} { focus $oldFocus } + # Procedure delete-database {target w} # target target to be defined # w top level widget for the target definition @@ -2265,11 +2449,10 @@ proc delete-database {target w} { # Procedure protocol-setup {target} # target target to be defined # Makes a dialog in which the user may modify/view a target definition -# (profile). The $targetS - array holds the initial definition of the +# (profile). The $profileS - array holds the initial definition of the # target. proc protocol-setup {target} { - global profile - global targetS + global profile profileS set bno 0 while {[winfo exists .setup-$bno]} { @@ -2283,16 +2466,18 @@ proc protocol-setup {target} { top-down-window $w - if {$target == ""} { + if {![string length $target]} { set target Default } - dputs target - dputs $profile($target) + foreach n [array names profile $target,*] { + set profileS($n) $profile($n) + } frame $w.top.description frame $w.top.host frame $w.top.port frame $w.top.idAuthentication + frame $w.top.cs-type -relief ridge -border 2 frame $w.top.protocol -relief ridge -border 2 frame $w.top.query -relief ridge -border 2 @@ -2311,24 +2496,15 @@ proc protocol-setup {target} { bind $w.top.$sub.entry [list add-database $target $w] bind $w.top.$sub.entry [list delete-database $target $w] } - $w.top.description.entry insert 0 [lindex $profile($target) 0] - $w.top.host.entry insert 0 [lindex $profile($target) 1] - $w.top.port.entry insert 0 [lindex $profile($target) 2] - $w.top.idAuthentication.entry insert 0 [lindex $profile($target) 3] - set targetS($target,csType) [lindex $profile($target) 6] - set targetS($target,RPN) [lindex $profile($target) 8] - set targetS($target,CCL) [lindex $profile($target) 9] - set targetS($target,ResultSets) [lindex $profile($target) 10] - set targetS($target,protocolType) [lindex $profile($target) 11] - if {$targetS($target,protocolType) == ""} { - set targetS($target,protocolType) Z39 - } - set targetS($target,LSLB) [lindex $profile($target) 13] - set targetS($target,SSUB) [lindex $profile($target) 14] - set targetS($target,MSPN) [lindex $profile($target) 15] - set targetS($target,presentChunk) [lindex $profile($target) 16] - set targetS($target,MRS) [lindex $profile($target) 4] - set targetS($target,PMS) [lindex $profile($target) 5] + $w.top.description.entry configure -textvariable \ + profileS($target,description) + $w.top.host.entry configure -textvariable \ + profileS($target,host) + $w.top.port.entry configure -textvariable \ + profileS($target,port) + $w.top.idAuthentication.entry configure -textvariable \ + profileS($target,authentication) + # Databases .... pack $w.top.databases -side left -pady 2 -padx 2 -expand yes -fill both @@ -2355,18 +2531,19 @@ proc protocol-setup {target} { -padx 2 -pady 2 $w.top.databases.scroll config -command "$w.top.databases.list yview" - foreach b [lindex $profile($target) 7] { - $w.top.databases.list insert end $b + if {[info exists profile($target,databases)]} { + foreach b $profile($target,databases) { + $w.top.databases.list insert end $b + } } - # Transport ... pack $w.top.cs-type -pady 2 -padx 2 -side top -fill x label $w.top.cs-type.label -text "Transport" radiobutton $w.top.cs-type.tcpip -text "TCP/IP" -anchor w \ - -variable targetS($target,csType) -value tcpip + -variable profileS($target,comstack) -value tcpip radiobutton $w.top.cs-type.mosi -text "MOSI" -anchor w\ - -variable targetS($target,csType) -value mosi + -variable profileS($target,comstack) -value mosi pack $w.top.cs-type.label $w.top.cs-type.tcpip $w.top.cs-type.mosi \ -padx 2 -side top -fill x @@ -2376,9 +2553,9 @@ proc protocol-setup {target} { label $w.top.protocol.label -text "Protocol" radiobutton $w.top.protocol.z39v2 -text "Z39.50" -anchor w \ - -variable targetS($target,protocolType) -value Z39 + -variable profileS($target,protocol) -value Z39 radiobutton $w.top.protocol.sr -text "SR" -anchor w \ - -variable targetS($target,protocolType) -value SR + -variable profileS($target,protocol) -value SR pack $w.top.protocol.label $w.top.protocol.z39v2 $w.top.protocol.sr \ -padx 2 -side top -fill x @@ -2388,11 +2565,11 @@ proc protocol-setup {target} { label $w.top.query.label -text "Query support" checkbutton $w.top.query.c1 -text "RPN query" -anchor w \ - -variable targetS($target,RPN) + -variable profileS($target,queryRPN) checkbutton $w.top.query.c2 -text "CCL query" -anchor w \ - -variable targetS($target,CCL) + -variable profileS($target,queryCCL) checkbutton $w.top.query.c3 -text "Result sets" -anchor w \ - -variable targetS($target,ResultSets) + -variable profileS($target,namedResultSets) pack $w.top.query.label -side top pack $w.top.query.c1 $w.top.query.c2 $w.top.query.c3 \ @@ -2412,7 +2589,7 @@ proc protocol-setup {target} { # of a target definition (profile). proc advanced-setup {target b} { global profile - global targetS + global profileS set w .advanced-setup-$b @@ -2422,7 +2599,7 @@ proc advanced-setup {target b} { top-down-window $w - if {$target == ""} { + if {![string length $target]} { set target Default } dputs target @@ -2447,12 +2624,18 @@ proc advanced-setup {target b} { {Maximum Record Size:} {Preferred Message Size:}} \ [list advanced-setup-action $target $b] [list destroy $w] - $w.top.largeSetLowerBound.entry insert 0 $targetS($target,LSLB) - $w.top.smallSetUpperBound.entry insert 0 $targetS($target,SSUB) - $w.top.mediumSetPresentNumber.entry insert 0 $targetS($target,MSPN) - $w.top.presentChunk.entry insert 0 $targetS($target,presentChunk) - $w.top.maximumRecordSize.entry insert 0 $targetS($target,MRS) - $w.top.preferredMessageSize.entry insert 0 $targetS($target,PMS) + $w.top.largeSetLowerBound.entry configure -textvariable \ + profileS($target,largeSetLowerBound) + $w.top.smallSetUpperBound.entry configure -textvariable \ + profileS($target,smallSetUpperBound) + $w.top.mediumSetPresentNumber.entry configure -textvariable \ + profileS($target,mediumSetPresentNumber) + $w.top.presentChunk.entry configure -textvariable \ + profileS($target,presentChunk) + $w.top.maximumRecordSize.entry configure -textvariable \ + profileS($target,maximumRecordSize) + $w.top.preferredMessageSize.entry configure -textvariable \ + profileS($target,preferredMessageSize) bottom-buttons $w [list {Ok} [list advanced-setup-action $target $b] \ {Cancel} [list destroy $w]] 0 @@ -2462,17 +2645,17 @@ proc advanced-setup {target b} { # target target to be defined # b window number of target top level # This procedure is called when the user hits Ok in the advanced target -# setup dialog. The temporary result is stored in the $targetS - array. +# setup dialog. The temporary result is stored in the $profileS - array. proc advanced-setup-action {target b} { set w .advanced-setup-$b - global targetS + global profileS - set targetS($target,LSLB) [$w.top.largeSetLowerBound.entry get] - set targetS($target,SSUB) [$w.top.smallSetUpperBound.entry get] - set targetS($target,MSPN) [$w.top.mediumSetPresentNumber.entry get] - set targetS($target,presentChunk) [$w.top.presentChunk.entry get] - set targetS($target,MRS) [$w.top.maximumRecordSize.entry get] - set targetS($target,PMS) [$w.top.preferredMessageSize.entry get] + set profileS($target,LSLB) [$w.top.largeSetLowerBound.entry get] + set profileS($target,SSUB) [$w.top.smallSetUpperBound.entry get] + set profileS($target,MSPN) [$w.top.mediumSetPresentNumber.entry get] + set profileS($target,presentChunk) [$w.top.presentChunk.entry get] + set profileS($target,MRS) [$w.top.maximumRecordSize.entry get] + set profileS($target,PMS) [$w.top.preferredMessageSize.entry get] dputs "advanced-setup-action" destroy $w @@ -2522,13 +2705,34 @@ proc database-select {} { -padx 2 -pady 2 $w.top.databases.scroll config -command "$w.top.databases.list yview" - foreach b [lindex $profile($hostid) 7] { + foreach b $profile($hostid,databases) { $w.top.databases.list insert end $b } top-down-ok-cancel $w {database-select-action} 1 focus $oldFocus } +# Procedure cascase-dblist-select +proc cascade-dblist-select {target db} { + show-target $target $db + z39 databaseNames $db +} + +# Procedure cascade-dblist +# Makes the Service/database list with proper databases for the target +proc cascade-dblist {target base} { + global profile + + set w .top.service.m.dblist + $w delete 0 200 + if {[info exists profile($target,databases)]} { + foreach db $profile($target,databases) { + $w add command -label $db \ + -command [list cascade-dblist-select $target $db] + } + } +} + # Procedure cascade-target-list # Makes all target/databases available in the Target|Connect # menu as well as all targets in the Target|Setup menu. @@ -2540,25 +2744,39 @@ proc cascade-target-list {} { destroy $sub } .top.target.m.clist delete 0 last - foreach n [lsort [array names profile]] { - if {$n != "Default"} { - set nl [lindex $profile($n) 12] - if {[llength [lindex $profile($n) 7]] > 1} { - .top.target.m.clist add cascade -label $n \ - -menu .top.target.m.clist.$nl - menu .top.target.m.clist.$nl - foreach b [lindex $profile($n) 7] { - .top.target.m.clist.$nl add command -label $b \ - -command [list reopen-target $n $b] - } - } else { - .top.target.m.clist add command -label $n \ - -command [list reopen-target $n {}] - } - } + foreach nn [lsort [array names profile *,host]] { + if {[string length $profile($nn)]} { + set ll [expr [string length $nn] - 6] + set n [string range $nn 0 $ll] + + set nl $profile($n,windowNumber) + if {[info exists profile($n,databases)]} { + set ndb [llength $profile($n,databases)] + } else { + set ndb 0 + } + if {$ndb > 1} { + .top.target.m.clist add cascade -label $n \ + -menu .top.target.m.clist.$nl + irmenu .top.target.m.clist.$nl + foreach b $profile($n,databases) { + .top.target.m.clist.$nl add command -label $b \ + -command [list reopen-target $n $b] + } + } elseif {$ndb == 1} { + .top.target.m.clist add command -label $n -command \ + [list reopen-target $n [lindex $profile($n,databases) 0]] + } else { + .top.target.m.clist add command -label $n -command \ + [list reopen-target $n {}] + } + } } .top.target.m.slist delete 0 last - foreach n [lsort [array names profile]] { + foreach nn [lsort [array names profile *,host]] { + set ll [expr [string length $nn] - 6] + set n [string range $nn 0 $ll] + .top.target.m.slist add command -label $n \ -command [list protocol-setup $n] } @@ -2707,26 +2925,28 @@ proc save-geometry {} { return } if {$hostid != "Default"} { - puts $f "set hostid \{$hostid\}" + puts $f "set hostid [list $hostid]" set b [z39 databaseNames] - puts $f "set hostbase $b" + puts $f "set hostbase [list $b]" } - puts $f "set hotTargets \{ $hotTargets \}" + puts $f "set hotTargets [list $hotTargets]" puts $f "set textWrap $textWrap" puts $f "set displayFormat $displayFormat" puts $f "set popupMarcdf $popupMarcdf" puts $f "set recordSyntax $recordSyntax" puts $f "set elementSetNames $elementSetNames" foreach n [array names windowGeometry] { - puts -nonewline $f "set \{windowGeometry($n)\} \{" - puts -nonewline $f $windowGeometry($n) - puts $f "\}" + dputs "set [list windowGeometry($n)] " + dputs [list $windowGeometry($n)] + + puts -nonewline $f "set [list windowGeometry($n)] " + puts $f [list $windowGeometry($n)] } close $f } # Procedure save-settings -# This procedure saves the per-host related settings clientrc.tcl which +# This procedure saves the per-host related settings irtdb.tcl which # is normally kept in the directory /usr/local/lib/irtcl. # All query types and target defintion profiles are saved. proc save-settings {} { @@ -2736,35 +2956,22 @@ proc save-settings {} { global queryTypes global queryButtons global queryInfo - - if {![file writable "${libdir}/clientrc.tcl"]} { - set a [alert "Cannot open ${libdir}/clientrc.tcl for writing. Do you \ - wish to save clientrc.tcl in the current directory instead?"] - if {! $a} { - return - } - set f [open "clientrc.tcl" w] + + if {[file writable "${libdir}/irtdb.tcl"]} { + set f [open "${libdir}/irtdb.tcl" w] } else { - set f [open "${libdir}/clientrc.tcl" w] + set f [open "irtdb.tcl" w] } puts $f "# Setup file" - foreach n [array names profile] { - puts -nonewline $f "set \{profile($n)\} \{" - puts -nonewline $f $profile($n) - puts $f "\}" + foreach n [lsort [array names profile]] { + puts $f "set [list profile($n)] [list $profile($n)]" } - puts -nonewline $f "set queryTypes \{" - puts -nonewline $f $queryTypes - puts $f "\}" + puts $f "set queryTypes [list $queryTypes]" - puts -nonewline $f "set queryButtons \{" - puts -nonewline $f $queryButtons - puts $f "\}" + puts $f "set queryButtons [list $queryButtons]" - puts -nonewline $f "set queryInfo \{" - puts -nonewline $f $queryInfo - puts $f "\}" + puts $f "set queryInfo [list $queryInfo]" close $f set settingsChanged 0 } @@ -2777,7 +2984,7 @@ proc save-settings {} { proc alert {ask} { set w .alert - global alertAnswer + global alertAnswer font toplevel $w set oldFocus [focus] @@ -2785,8 +2992,7 @@ proc alert {ask} { top-down-window $w label $w.top.warning -bitmap warning - message $w.top.message -text $ask -aspect 300 \ - -font -Adobe-Times-Medium-R-Normal-*-180-* + message $w.top.message -text $ask -aspect 300 -font $font(b,normal) pack $w.top.warning $w.top.message -side left -pady 5 -padx 10 -expand yes @@ -2805,16 +3011,12 @@ proc alert-action {} { } # Procedure exit-action -# This procedure is called if the user tries to exit without saving the -# system settings. +# This procedure is called if the user exists the application proc exit-action {} { global settingsChanged if {$settingsChanged} { - set a [alert "you haven't saved your settings. Do you wish to save?"] - if {$a} { - save-settings - } + save-settings } save-geometry exit 0 @@ -2849,7 +3051,7 @@ proc listbuttonx {button no names handle user} { } else { menubutton $button -text [lindex [lindex $names $no] 0] \ -width 10 -menu ${button}.m -relief raised -border 1 - menu ${button}.m + irmenu ${button}.m if {[tk4]} { ${button}.m configure -tearoff off } @@ -2872,7 +3074,7 @@ proc listbuttonx {button no names handle user} { proc listbutton {button no names} { menubutton $button -text [lindex $names $no] -width 10 -menu ${button}.m \ -relief raised -border 1 - menu ${button}.m + irmenu ${button}.m if {[tk4]} { ${button}.m configure -tearoff off } @@ -2921,7 +3123,7 @@ proc listbuttonv {button var names} { } menubutton $button -text $n -menu ${button}.m \ -relief raised -border 1 - menu ${button}.m + irmenu ${button}.m if {[tk4]} { ${button}.m configure -tearoff off } @@ -3195,6 +3397,7 @@ proc use-attr {init} { {Host item} 1033 {Content type} 1034 {Anywhere} 1035 + {Author-Title-Subject} 1036 } set w .index-setup global useTmpValue @@ -3413,7 +3616,7 @@ proc query-edit-index {queryNo} { set w .query-setup set i [lindex [$w.top.index.list curselection] 0] - if {$i == ""} { + if {![string length $i]} { return } set attr [lindex $queryInfoTmp $i] @@ -3431,7 +3634,7 @@ proc query-delete-index {queryNo} { set w .query-setup set i [lindex [$w.top.index.list curselection] 0] - if {$i == ""} { + if {![string length $i]} { return } set queryInfoTmp [lreplace $queryInfoTmp $i $i] @@ -3652,8 +3855,10 @@ proc index-lines {w realOp buttonInfo queryInfo handle} { if {! [winfo exists $w.$i.e]} { entry $w.$i.e -width 32 -relief sunken -border 1 bind $w.$i.e [list index-focus-in $w $i] - bind $w.$i.e [list $w.$i configure \ - -background white] + if {![tk4]} { + bind $w.$i.e [list $w.$i configure \ + -background white] + } pack $w.$i.l -side left pack $w.$i.e -side left -fill x -expand yes pack $w.$i -side top -fill x -padx 2 -pady 2 @@ -3734,14 +3939,6 @@ proc search-fields {w buttondefs} { $w.0 configure -background red } -# Init: The geometry information for the main window is set - either -# to a default value or to the value in windowGeometry(.) -if {[catch {set g $windowGeometry(.)}]} { - wm geometry . 420x340 -} else { - wm geometry . $g -} - # Init: Presentation formats are read. read-formats @@ -3757,14 +3954,14 @@ pack .bot -fill x # Init: Definition of File menu. menubutton .top.file -text File -menu .top.file.m -menu .top.file.m +irmenu .top.file.m .top.file.m add command -label {Save settings} -command {save-settings} .top.file.m add separator .top.file.m add command -label Exit -command {exit-action} # Init: Definition of Target menu. menubutton .top.target -text Target -menu .top.target.m -menu .top.target.m +irmenu .top.target.m .top.target.m add cascade -label Connect -menu .top.target.m.clist .top.target.m add command -label Disconnect -command {close-target} .top.target.m add command -label About -command {about-target} @@ -3776,33 +3973,38 @@ set-target-hotlist 0 configure-disable-e .top.target.m 1 configure-disable-e .top.target.m 2 -menu .top.target.m.clist -menu .top.target.m.slist +irmenu .top.target.m.clist +irmenu .top.target.m.slist cascade-target-list # Init: Definition of Service menu. menubutton .top.service -text Service -menu .top.service.m -menu .top.service.m -.top.service.m add command -label Database -command {database-select} +irmenu .top.service.m +.top.service.m add cascade -label Database -menu .top.service.m.dblist .top.service.m add cascade -label Present -menu .top.service.m.present -menu .top.service.m.present -.top.service.m.present add command -label {10 More} \ - -command [list present-more 10] +irmenu .top.service.m.present +.top.service.m.present add command -label {50 More} \ + -command [list present-more 50] .top.service.m.present add command -label All \ -command [list present-more {}] .top.service.m add command -label Search -command {search-request 0} .top.service.m add command -label Scan -command {scan-request} +.top.service.m add command -label Explain -command \ + {explain-refresh $hostid {ready-response {}} } .top.service configure -state disabled +irmenu .top.service.m.dblist + +# Init: Definition of Set menu. menubutton .top.rset -text Set -menu .top.rset.m -menu .top.rset.m +irmenu .top.rset.m .top.rset.m add command -label Load -command {load-set} .top.rset.m add separator # Init: Definition of the Options menu. menubutton .top.options -text Options -menu .top.options.m -menu .top.options.m +irmenu .top.options.m .top.options.m add cascade -label Query -menu .top.options.m.query .top.options.m add cascade -label Format -menu .top.options.m.formats .top.options.m add cascade -label Wrap -menu .top.options.m.wrap @@ -3811,7 +4013,7 @@ menu .top.options.m .top.options.m add radiobutton -label Debug -variable debugMode -value 1 # Init: Definition of the Options|Query menu. -menu .top.options.m.query +irmenu .top.options.m.query .top.options.m.query add cascade -label Select \ -menu .top.options.m.query.clist .top.options.m.query add cascade -label Edit \ @@ -3821,13 +4023,13 @@ menu .top.options.m.query .top.options.m.query add cascade -label Delete \ -menu .top.options.m.query.dlist -menu .top.options.m.query.slist -menu .top.options.m.query.clist -menu .top.options.m.query.dlist +irmenu .top.options.m.query.slist +irmenu .top.options.m.query.clist +irmenu .top.options.m.query.dlist cascade-query-list # Init: Definition of the Options|Formats menu. -menu .top.options.m.formats +irmenu .top.options.m.formats set i 0 foreach f $displayFormats { .top.options.m.formats add radiobutton -label $f -value $i \ @@ -3836,7 +4038,7 @@ foreach f $displayFormats { } # Init: Definition of the Options|Wrap menu. -menu .top.options.m.wrap +irmenu .top.options.m.wrap .top.options.m.wrap add radiobutton -label Character \ -value char -variable textWrap -command {set-wrap char} .top.options.m.wrap add radiobutton -label Word \ @@ -3845,7 +4047,7 @@ menu .top.options.m.wrap -value none -variable textWrap -command {set-wrap none} # Init: Definition of the Options|Syntax menu. -menu .top.options.m.syntax +irmenu .top.options.m.syntax .top.options.m.syntax add radiobutton -label None \ -value None -variable recordSyntax .top.options.m.syntax add separator @@ -3871,7 +4073,7 @@ menu .top.options.m.syntax -value GRS1 -variable recordSyntax # Init: Definition of the Options|Elements menu. -menu .top.options.m.elements +irmenu .top.options.m.elements .top.options.m.elements add radiobutton -label Unspecified \ -value None -variable elementSetNames .top.options.m.elements add radiobutton -label Full \ @@ -3881,10 +4083,8 @@ menu .top.options.m.elements # Init: Definition of Help menu. menubutton .top.help -text "Help" -menu .top.help.m -menu .top.help.m +irmenu .top.help.m -.top.help.m add command -label "Help on help" \ - -command {tkerror "Help on help not available. Sorry"} .top.help.m add command -label "About" -command {about-origin} # Init: Pack menu bar items. @@ -3898,7 +4098,7 @@ button .mid.search -text Search -command {search-request 0} \ -state disabled button .mid.scan -text Scan \ -command scan-request -state disabled -button .mid.present -text {Present} -command [list present-more 10] \ +button .mid.present -text {Present} -command [list present-more 50] \ -state disabled button .mid.clear -text Clear -command index-clear @@ -3906,13 +4106,15 @@ pack .mid.search .mid.scan .mid.present .mid.clear -side left \ -fill y -pady 1 # Init: Define record area in main window. -text .data.record -font fixed -height 2 -width 20 -wrap none -borderwidth 0 -relief flat \ - -yscrollcommand [list .data.scroll set] -wrap $textWrap +text .data.record -font fixed -height 2 -width 20 -wrap none -borderwidth 0 \ + -relief flat -yscrollcommand [list .data.scroll set] \ + -wrap $textWrap -background grey85 scrollbar .data.scroll -command [list .data.record yview] if {[tk4]} { .data.record configure -takefocus 0 .data.scroll configure -takefocus 0 } + pack .data.scroll -side right -fill y pack .data.record -expand yes -fill both initBindings @@ -3927,19 +4129,15 @@ if {! $monoFlag} { .data.record tag configure marc-id -foreground black } .data.record tag configure marc-data -foreground black -.data.record tag configure marc-head \ - -font -Adobe-Times-Bold-R-Normal-*-140-* \ +.data.record tag configure marc-head -font $font(n,normal) \ -foreground brown -relief raised -borderwidth 1 .data.record tag configure marc-small-head -foreground brown .data.record tag configure marc-pref \ - -font -Adobe-Times-Medium-R-Normal-*-140-* \ - -foreground blue + -font $font(n,normal) -foreground blue .data.record tag configure marc-text \ - -font -Adobe-Times-Medium-R-Normal-*-140-* \ - -foreground black + -font $font(n,normal) -foreground black .data.record tag configure marc-it \ - -font -Adobe-Times-Medium-I-Normal-*-140-* \ - -foreground black + -font $font(n,normal) -foreground black # Init: Define logo. button .bot.logo -bitmap @${libdir}/bitmaps/book1 -command cancel-operation @@ -3951,7 +4149,7 @@ frame .bot.a pack .bot.a -side left -fill x pack .bot.logo -side right -padx 2 -pady 2 -ipadx 1 -message .bot.a.target -text "" -aspect 1000 -border 1 +message .bot.a.target -text {} -aspect 2000 -border 1 label .bot.a.status -text "Not connected" -width 15 -relief \ sunken -anchor w -border 1 @@ -3966,23 +4164,38 @@ pack .bot.a.status .bot.a.set .bot.a.message \ # Init: Determine if the IrTcl extension is already there. If # not, then dynamically load the IrTcl extension. -if {[catch {ir z39}]} { +set logLevel all +if {[catch {ir-version}]} { set e [info sharedlibextension] - puts -nonewline "Loading irtcl$e ..." - load irtcl$e irtcl - ir z39 - puts "ok" + catch {load ${libdir}/irtcl$e irtcl} + if {[catch {ir-version}]} { + catch {load irtcl$e irtcl} + } } -# Init: Uncomment this line if you wan't to enable logging. -z39 logLevel all +if $debugMode { + ir-log-init all {} irtcl.log +} else { + ir-log-init none {} {} +} -# Init: If hostid is a valid target, a new connection will be established -# immediately. -if {$hostid != "Default"} { - catch {open-target $hostid $hostbase} +# Create Z Assocation +ir z39 + +if {[file exists ${libdir}/explain.tcl]} { + source ${libdir}/explain.tcl } -# Init: Enable the logo. -show-logo 1 +if {[file exists ${libdir}/setup.tcl]} { + source ${libdir}/setup.tcl +} +after 10 activateMainWindow + +proc activateMainWindow {} { + global hostid hostbase + if {[string compare $hostid Default]} { + catch {open-target $hostid $hostbase} + } + show-logo 1 +}