X-Git-Url: http://lists.indexdata.com/cgi-bin?a=blobdiff_plain;f=client.tcl;h=405ea0dabf0c0db2d193fcaca7641bf1bef06ee2;hb=cd15ffa62cfab32a1b984f7dc587dfc403f0d11f;hp=8b7b98458ed6877210568420572469fb6cadaf5e;hpb=578c2b7c38c27fa17a59d6dee9beebc34668e76f;p=ir-tcl-moved-to-github.git diff --git a/client.tcl b/client.tcl index 8b7b984..405ea0d 100644 --- a/client.tcl +++ b/client.tcl @@ -4,7 +4,23 @@ # Sebastian Hammer, Adam Dickmeiss # # $Log: client.tcl,v $ -# Revision 1.55 1995-06-27 17:10:37 adam +# Revision 1.60 1995-06-30 16:30:19 adam +# Minor changes. +# +# Revision 1.59 1995/06/29 14:06:25 adam +# Another bug in install fixed. Configure searches for more versions of yaz. +# +# Revision 1.58 1995/06/29 12:34:06 adam +# IrTcl now works with both tk4.0b4/tcl7.4b4 and tk3.6/tcl7.3 +# +# Revision 1.57 1995/06/29 09:20:30 adam +# Target entries in cascade menus are sorted. +# +# Revision 1.56 1995/06/27 19:03:48 adam +# Bug fix in do_present in ir-tcl.c: p->set_child member weren't set. +# nextResultSetPosition used instead of setOffset. +# +# Revision 1.55 1995/06/27 17:10:37 adam # Bug fix: install procedure didn't work on some systems. # Error turned up when clientrc.tcl was't present. # @@ -196,9 +212,45 @@ # # +if {$tk_version == "3.6"} { + set tk4 0 +} else { + set tk4 1 +} + +if {$tk4} { + proc configure-enable-e {w n} { + incr n + $w entryconfigure $n -state normal + } + proc configure-disable-e {w n} { + incr n + $w entryconfigure $n -state disabled + } + set noFocus [list -takefocus 0] +} else { + proc configure-enable-e {w n} { + $w enable $n + } + proc configure-disable-e {w n} { + $w disable $n + } + set noFocus {} +} + +if {! $tk4} { + if {[tk colormodel .] == "color"} { + set monoFlag 0 + } else { + set monoFlag 1 + } +} else { + set monoFlag 0 +} + set libdir LIBDIR if {[file readable bitmaps/book2]} { - set libdir . + set libdir . } if {! [file readable ${libdir}/bitmaps/book2]} { puts "Cannot locate system files in ${libdir}. You must either run this" @@ -215,6 +267,7 @@ set profile(Default) {{} {} {210} {} 16384 8192 tcpip {} 1 {} {} Z39 1} set hostid Default set settingsChanged 0 set setNo 0 +set setNoLast 0 set cancelFlag 0 set scanEnable 0 set fullMarcSeq 0 @@ -247,7 +300,7 @@ proc tkerror err { label $w.top.b -bitmap error message $w.top.t -aspect 300 -text "Error: $err" \ - -font -Adobe-Helvetica-Bold-R-Normal-*-240-* + -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 @@ -276,7 +329,7 @@ proc set-wrap {m} { } proc dputs {m} { -# puts $m +# puts $m } proc set-display-format {f} { @@ -293,9 +346,6 @@ proc set-display-format {f} { } update idletasks add-title-lines -1 10000 1 - if {!$busy} { - .bot.a.status configure -text "Ready" - } } proc initBindings {} { @@ -483,12 +533,14 @@ proc show-status {status b sb} { .mid.scan configure -state normal } if {$setNo == 0} { - .top.service.m disable 1 - } elseif {$setOffset > 0 && $setOffset <= [z39.$setNo resultCount]} { - .top.service.m enable 1 + configure-disable-e .top.service.m 1 + } elseif {[z39.$setNo nextResultSetPosition] > 0 && + [z39.$setNo nextResultSetPosition] <= [z39.$setNo resultCount]} { + configure-enable-e .top.service.m 1 .mid.present configure -state normal } else { - .top.service.m disable 1 + configure-disable-e .top.service.m 1 + .mid.present configure -state disabled } if {[winfo exists .scan-window]} { .scan-window.bot.2 configure -state normal @@ -670,7 +722,8 @@ proc popup-marc {sno no b df} { -yscrollcommand [list $w.top.s set] scrollbar $w.top.s -command [list $w.top.record yview] - if {[tk colormodel .] == "color"} { + global monoFlag + if {! $monoFlag} { $w.top.record tag configure marc-tag -foreground blue $w.top.record tag configure marc-id -foreground red } else { @@ -711,8 +764,10 @@ proc popup-marc {sno no b df} { } } else { set i 0 + $w.bot.formats.m delete 0 last foreach f $displayFormats { - $w.bot.formats.m entryconfigure $i \ + $w.bot.formats.m add radiobutton -label $f \ + -variable popupMarcdf -value $i \ -command [list display-$f $sno $no $w.top.record 0] incr i } @@ -725,10 +780,15 @@ proc popup-marc {sno no b df} { proc update-target-hotlist {target base} { global hotTargets + global tk4 set len [llength $hotTargets] if {$len > 0} { - .top.target.m delete 6 [expr 6+[llength $hotTargets]] + if {$tk4} { + .top.target.m delete 7 [expr 7+[llength $hotTargets]] + } else { + .top.target.m delete 6 [expr 6+[llength $hotTargets]] + } } set i 0 foreach e $hotTargets { @@ -832,22 +892,25 @@ proc open-target {target base} { } errorMessage] if {$err} { tkerror $errorMessage - show-status Ready 0 {} + show-status "Not connected" 0 {} return } set hostid $target - .top.target.m disable 0 - .top.target.m enable 1 - .top.target.m enable 2 + configure-disable-e .top.target.m 0 + configure-enable-e .top.target.m 1 + configure-enable-e .top.target.m 2 } proc close-target {} { global hostid global cancelFlag global setNo + global setNoLast + global tk4 set cancelFlag 0 set setNo 0 + set setNoLast 0 .bot.a.set configure -text "" set hostid Default z39 disconnect @@ -855,31 +918,36 @@ proc close-target {} { show-status {Not connected} 0 0 init-title-lines show-message {} - .top.target.m disable 1 - .top.target.m disable 2 - .top.rset.m delete 2 last - .top.target.m enable 0 + configure-disable-e .top.target.m 1 + configure-disable-e .top.target.m 2 + if {$tk4} { + .top.rset.m delete 2 last + } else { + .top.rset.m delete 1 last + } + .top.rset.m add separator + configure-enable-e .top.target.m 0 } proc load-set-action {} { - global setNo + global setNoLast - incr setNo - ir-set z39.$setNo z39 + incr setNoLast + ir-set z39.$setNoLast z39 set fname [.load-set.top.filename.entry get] destroy .load-set if {$fname != ""} { show-status {Loading} 1 {} update - z39.$setNo loadFile $fname + z39.$setNoLast loadFile $fname - set no [z39.$setNo numberOfRecordsReturned] - add-title-lines $setNo $no 1 + set no [z39.$setNoLast numberOfRecordsReturned] + add-title-lines $setNoLast $no 1 } - set l [format "%-4d %7d" $setNo $no] + set l [format "%-4d %7d" $setNoLast $no] .top.rset.m add command -label $l \ - -command [list add-title-lines $setNo 10000 1] + -command [list add-title-lines $setNoLast 10000 1] show-status {Ready} 0 {} } @@ -904,7 +972,6 @@ proc load-set {} { } proc init-request {} { - global setNo global cancelFlag if {$cancelFlag} { @@ -945,6 +1012,7 @@ proc init-response {} { proc search-request {bflag} { global setNo + global setNoLast global profile global hostid global busy @@ -972,7 +1040,8 @@ proc search-request {bflag} { if {$query==""} { return } - incr setNo + incr setNoLast + set setNo $setNoLast ir-set z39.$setNo z39 if {[lindex $profile($target) 10] == 1} { @@ -1052,23 +1121,19 @@ proc scan-request {} { entry $w.top.entry -relief sunken pack $w.top.entry -fill x -padx 4 -pady 2 bind $w.top.entry [list scan-term-h $attr] - if {1} { - listbox $w.top.list -yscrollcommand [list $w.top.scroll set] \ - -font fixed - scrollbar $w.top.scroll -orient vertical -border 1 - pack $w.top.list -side left -fill both -expand yes - pack $w.top.scroll -side right -fill y - $w.top.scroll config -command [list $w.top.list yview] - } else { - listbox $w.top.list -font fixed -geometry 60x14 - pack $w.top.list -side left -fill both -expand yes - } + listbox $w.top.list -yscrollcommand [list $w.top.scroll set] \ + -font fixed + scrollbar $w.top.scroll -orient vertical -border 1 + pack $w.top.list -side left -fill both -expand yes + pack $w.top.scroll -side right -fill y + $w.top.scroll config -command [list $w.top.list yview] bottom-buttons $w [list {Close} [list destroy $w] \ {Up} [list scan-up $attr] \ {Down} [list scan-down $attr]] 0 bind $w.top.list [list scan-up $attr] bind $w.top.list [list scan-down $attr] + focus $w.top.entry } bind $w.top.list [list scan-copy %y $curIndexEntry] wm title $w "Scan $title" @@ -1299,15 +1364,13 @@ proc search-response {} { show-status {Ready} 0 1 set status [z39.$setNo responseStatus] if {[lindex $status 0] == "NSD"} { + z39.$setNo nextResultSetPosition 0 set code [lindex $status 1] set msg [lindex $status 2] set addinfo [lindex $status 3] tkerror "NSD$code: $msg: $addinfo" return } - if {$setMax > 20} { - set setMax 20 - } show-message "${setMax} hits" if {$setMax == 0} { return @@ -1317,6 +1380,9 @@ proc search-response {} { set l [format "%-4d %7d" $setNo $setMax] .top.rset.m add command -label $l \ -command [list add-title-lines $setNo 10000 1] + if {$setMax > 20} { + set setMax 20 + } z39 callback {present-response} z39.$setNo present $setOffset 1 show-status {Retrieving} 1 0 @@ -1342,10 +1408,14 @@ proc present-more {number} { dputs "setNo=$setNo" return } + set setOffset [z39.$setNo nextResultSetPosition] + dputs "setOffest=${setOffset}" + dputs "setNo=${setNo}" set max [z39.$setNo resultCount] - if {$max <= $setOffset} { + if {$max < $setOffset} { dputs "max=$max" dputs "setOffset=$setOffset" + show-status Ready 0 1 return } if {$number == ""} { @@ -1380,12 +1450,13 @@ proc title-press {y setno} { proc add-title-lines {setno no offset} { global displayFormats global displayFormat - global lastSetNo + global setNo + global busy - if {$setno == -1} { - set setno $lastSetNo + if {$setno != -1} { + set setNo $setno } else { - set lastSetNo $setno + set setno $setNo } if {$offset == 1} { .bot.a.set configure -text $setno @@ -1409,6 +1480,9 @@ proc add-title-lines {setno no offset} { [list popup-marc $setno $o 0 0] update idletasks } + if {!$busy} { + show-status Ready 0 1 + } } proc present-response {} { @@ -1458,28 +1532,38 @@ proc left-cursor {w} { incr i -1 $w icursor $i } + dputs left } proc right-cursor {w} { set i [$w index insert] incr i + dputs right $w icursor $i } proc bind-fields {list returnAction escapeAction} { + global tk4 set max [expr [llength $list]-1] for {set i 0} {$i < $max} {incr i} { bind [lindex $list $i] $returnAction bind [lindex $list $i] $escapeAction - bind [lindex $list $i] [list focus [lindex $list [expr $i+1]]] - bind [lindex $list $i] [list left-cursor [lindex $list $i]] - bind [lindex $list $i] [list right-cursor [lindex $list $i]] + if {!$tk4} { + bind [lindex $list $i] \ + [list focus [lindex $list [expr $i+1]]] + bind [lindex $list $i] \ + [list left-cursor [lindex $list $i]] + bind [lindex $list $i] \ + [list right-cursor [lindex $list $i]] + } } bind [lindex $list $i] $returnAction bind [lindex $list $i] $escapeAction - bind [lindex $list $i] [list focus [lindex $list 0]] - bind [lindex $list $i] [list left-cursor [lindex $list $i]] - bind [lindex $list $i] [list right-cursor [lindex $list $i]] + if {!$tk4} { + bind [lindex $list $i] [list focus [lindex $list 0]] + bind [lindex $list $i] [list left-cursor [lindex $list $i]] + bind [lindex $list $i] [list right-cursor [lindex $list $i]] + } focus [lindex $list 0] } @@ -1656,9 +1740,9 @@ proc protocol-setup {target} { dputs target dputs $profile($target) + frame $w.top.description frame $w.top.host frame $w.top.port - frame $w.top.description frame $w.top.idAuthentication frame $w.top.maximumRecordSize frame $w.top.preferredMessageSize @@ -1707,8 +1791,14 @@ proc protocol-setup {target} { -command [list add-database $target] button $w.top.databases.delete -text "Delete" \ -command [list delete-database $target] - listbox $w.top.databases.list -geometry 20x6 \ - -yscrollcommand "$w.top.databases.scroll set" + global tk4 + if {! $tk4} { + listbox $w.top.databases.list -geometry 20x6 \ + -yscrollcommand "$w.top.databases.scroll set" + } else { + listbox $w.top.databases.list -width 20 \ + -yscrollcommand "$w.top.databases.scroll set" + } scrollbar $w.top.databases.scroll -orient vertical -border 1 pack $w.top.databases.label -side top -fill x \ -padx 2 -pady 2 @@ -1818,7 +1908,7 @@ proc cascade-target-list {} { destroy $sub } .top.target.m.clist delete 0 last - foreach n [array names profile] { + foreach n [lsort [array names profile]] { if {$n != "Default"} { set nl [lindex $profile($n) 12] if {[llength [lindex $profile($n) 7]] > 1} { @@ -1836,7 +1926,7 @@ proc cascade-target-list {} { } } .top.target.m.slist delete 0 last - foreach n [array names profile] { + foreach n [lsort [array names profile]] { if {$n != "Default"} { .top.target.m.slist add command -label $n \ -command [list protocol-setup $n] @@ -2336,6 +2426,7 @@ proc use-attr {init} { {Content type} 1034 {Anywhere} 1035 } + global tk4 set w .index-setup global useTmpValue set l [llength $attr] @@ -2351,8 +2442,13 @@ proc use-attr {init} { } incr lno } - $w.top.use.list select from $s - $w.top.use.list select to $s + if {$tk4} { + $w.top.use.list selection clear 0 end + $w.top.use.list selection set $s $s + } else { + $w.top.use.list select from $s + $w.top.use.list select to $s + } incr s -3 if {$s < 0} { set s 0 @@ -2414,6 +2510,7 @@ proc index-setup {attr queryNo indexNo} { global completenessTmpValue global positionTmpValue global useTmpValue + global tk4 set relationTmpValue 0 set truncationTmpValue 0 set structureTmpValue 0 @@ -2468,8 +2565,13 @@ proc index-setup {attr queryNo indexNo} { pack $w.top.use -side left -pady 6 -padx 6 -fill y label $w.top.use.label -text "Use" - listbox $w.top.use.list -geometry 26x10 \ - -yscrollcommand "$w.top.use.scroll set" + if {$tk4} { + listbox $w.top.use.list -width 26 \ + -yscrollcommand "$w.top.use.scroll set" + } else { + listbox $w.top.use.list -geometry 26x10 \ + -yscrollcommand "$w.top.use.scroll set" + } scrollbar $w.top.use.scroll -orient vertical -border 1 pack $w.top.use.label -side top -fill x \ -padx 2 -pady 2 @@ -2559,6 +2661,7 @@ proc query-setup {queryNo} { global queryButtonsTmp global queryInfoTmp global queryIndexTmp + global tk4 set queryIndexTmp 0 set queryName [lindex $queryTypes $queryNo] @@ -2601,8 +2704,13 @@ proc query-setup {queryNo} { pack $w.top.index.list -side left -fill both -expand yes -padx 2 -pady 2 pack $w.top.index.scroll -side right -fill y -padx 2 -pady 2 - $w.top.index.list select from 0 - $w.top.index.list select to 0 + if {$tk4} { + $w.top.index.list selection clear 0 end + $w.top.index.list selection set 0 0 + } else { + $w.top.index.list select from 0 + $w.top.index.list select to 0 + } foreach x $queryInfoTmp { $w.top.index.list insert end [lindex $x 0] @@ -2675,16 +2783,24 @@ proc index-query {} { proc index-focus-in {w i} { global curIndexEntry + global tk4 - $w.$i configure -background red + if {! $tk4} { + $w.$i configure -background red + } set curIndexEntry $i } proc index-lines {w realOp buttonInfo queryInfo handle} { + global tk4 set i 0 foreach b $buttonInfo { if {! [winfo exists $w.$i]} { - frame $w.$i -background white -border 1 + if {$tk4} { + frame $w.$i -border 0 + } else { + frame $w.$i -background white -border 1 + } } listbuttonx $w.$i.l [lindex $b 1] $queryInfo $handle $i @@ -2697,8 +2813,10 @@ proc index-lines {w realOp buttonInfo queryInfo handle} { 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 - bind $w.$i.e [list left-cursor $w.$i.e] - bind $w.$i.e [list right-cursor $w.$i.e] + if {!$tk4} { + bind $w.$i.e [list left-cursor $w.$i.e] + bind $w.$i.e [list right-cursor $w.$i.e] + } bind $w.$i.e {search-request 0} } } else { @@ -2715,15 +2833,19 @@ proc index-lines {w realOp buttonInfo queryInfo handle} { if {! $realOp} { return } - set j 0 - incr i -1 - while {$j < $i} { - set k [expr $j+1] - bind $w.$j.e "focus $w.$k.e" - set j $k + if {! $tk4} { + set j 0 + incr i -1 + while {$j < $i} { + set k [expr $j+1] + bind $w.$j.e "focus $w.$k.e" + set j $k + } } if {$i >= 0} { - bind $w.$i.e "focus $w.0.e" + if {! $tk4} { + bind $w.$i.e "focus $w.0.e" + } focus $w.0.e } } @@ -2796,8 +2918,8 @@ menu .top.target.m .top.target.m add separator set-target-hotlist -.top.target.m disable 1 -.top.target.m disable 2 +configure-disable-e .top.target.m 1 +configure-disable-e .top.target.m 2 menu .top.target.m.clist menu .top.target.m.slist @@ -2908,11 +3030,15 @@ pack .mid.search .mid.scan .mid.present .mid.clear -side left \ text .data.record -height 2 -width 20 -wrap none \ -yscrollcommand [list .data.scroll set] -wrap $textWrap 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 -if {[tk colormodel .] == "color"} { +if {! $monoFlag} { .data.record tag configure marc-tag -foreground blue .data.record tag configure marc-id -foreground red } else { @@ -2922,6 +3048,9 @@ if {[tk colormodel .] == "color"} { .data.record tag configure marc-data -foreground black button .bot.logo -bitmap @${libdir}/bitmaps/book1 -command cancel-operation +if {$tk4} { + .bot.logo configure -takefocus 0 +} frame .bot.a pack .bot.a -side left -fill x pack .bot.logo -side right -padx 2 -pady 2