X-Git-Url: http://lists.indexdata.dk/cgi-bin?a=blobdiff_plain;f=client.tcl;h=f4c37c8dac75a595888cdf2e8ef3ce5c33fc393b;hb=aa30eee6a1b9d8b08982965c7235ba3b806e94b9;hp=ff682193cafd654abfdb13f06628b5090871aaa5;hpb=7470e1bbfcf80e252bca329457c48e093dcbca20;p=ir-tcl-moved-to-github.git diff --git a/client.tcl b/client.tcl index ff68219..f4c37c8 100644 --- a/client.tcl +++ b/client.tcl @@ -1,6 +1,12 @@ # # $Log: client.tcl,v $ -# Revision 1.28 1995-06-02 14:52:13 adam +# Revision 1.30 1995-06-06 11:35:41 adam +# Work on scan. Display of old sets. +# +# Revision 1.29 1995/06/05 14:11:18 adam +# Bug fix in present-more. +# +# Revision 1.28 1995/06/02 14:52:13 adam # Minor changes really. # # Revision 1.27 1995/06/02 14:29:42 adam @@ -215,7 +221,7 @@ proc show-status {status b sb} { return } if {$sb} { - .top.search configure -state normal + .top.service configure -state normal .mid.search configure -state normal .mid.scan configure -state normal .mid.present configure -state normal @@ -225,7 +231,7 @@ proc show-status {status b sb} { } set searchEnable 1 } else { - .top.search configure -state disabled + .top.service configure -state disabled .mid.search configure -state disabled .mid.scan configure -state disabled .mid.present configure -state disabled @@ -295,11 +301,10 @@ proc about-origin {} { bottom-buttons $w [list {Close} [list destroy $w]] 1 } -proc show-full-marc {no b} { - global setNo +proc show-full-marc {sno no b} { global fullMarcSeq - if {[z39.$setNo type $no] != "DB"} { + if {[z39.$sno type $no] != "DB"} { return } if {$b} { @@ -329,7 +334,7 @@ proc show-full-marc {no b} { set new 1 } - set r [z39.$setNo getMarc $no list * * *] + set r [z39.$sno getMarc $no list * * *] $w.top.record tag configure marc-tag -foreground blue $w.top.record tag configure marc-data -foreground black @@ -364,7 +369,7 @@ proc show-full-marc {no b} { bottom-buttons $w [list \ {Close} [list destroy $w] \ - {Duplicate} [list show-full-marc $no 1]] 0 + {Duplicate} [list show-full-marc $sno $no 1]] 0 } } @@ -455,7 +460,7 @@ proc open-target {target base} { z39 failback [list fail-response $target] z39 callback [list connect-response $target] z39 connect [lindex $profile($target) 1]:[lindex $profile($target) 2] - z39 options search present scan namedResultSets triggerResourceCtrl +# z39 options search present scan namedResultSets triggerResourceCtrl show-status {Connecting} 1 {} set hostid $target .top.target.m disable 0 @@ -495,6 +500,9 @@ proc load-set-action {} { set no [z39.$setNo numberOfRecordsReturned] add-title-lines $setNo $no 1 } + set l [format "%-4d %7d" $setNo $no] + .top.rset.m add command -label $l \ + -command [list add-title-lines $setNo 10000 1] show-status {Ready} 0 {} } @@ -592,13 +600,14 @@ proc scan-request {attr} { global profile global hostid global scanView + global scanTerm set target $hostid set scanView 0 + set scanTerm {} ir-scan z39.scan z39 - z39 callback [list scan-response $attr 0 25] if {![winfo exists $w]} { toplevel $w @@ -607,7 +616,10 @@ proc scan-request {attr} { wm minsize $w 0 0 top-down-window $w - + + 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 -geometry 50x14 @@ -626,17 +638,44 @@ proc scan-request {attr} { bind $w.top.list [list scan-up $attr] bind $w.top.list [list scan-down $attr] } - focus $w.top.list + focus $w.top.entry + z39 callback [list scan-response $attr 0 25] z39.scan numberOfTermsRequested 5 z39.scan preferredPositionInResponse 1 - z39.scan scan "${attr} b" + z39.scan scan "${attr} 0" show-status {Scan} 1 0 } +proc scan-term-h {attr} { + global busy + global scanTerm + + if {$busy} { + return + } + set w .scan-window + set nScanTerm [$w.top.entry get] + if {$nScanTerm == $scanTerm} { + return + } + set scanTerm $nScanTerm + z39 callback [list scan-response $attr 0 25] + z39.scan numberOfTermsRequested 5 + z39.scan preferredPositionInResponse 1 + $w.top.list delete 0 end + puts "${attr} \{${scanTerm}\}" + if {$scanTerm == ""} { + z39.scan scan "${attr} 0" + } else { + z39.scan scan "${attr} \{${scanTerm}\}" + } + show-status {Scan} 1 0 +} proc scan-response {attr start toget} { global cancelFlag + global scanTerm set w .scan-window puts "In scan-response" @@ -651,6 +690,21 @@ proc scan-response {attr start toget} { set cancelFlag 0 return } + set nScanTerm [$w.top.entry get] + if {$nScanTerm != $scanTerm} { + z39 callback [list scan-response $attr 0 25] + z39.scan numberOfTermsRequested 5 + z39.scan preferredPositionInResponse 1 + set scanTerm $nScanTerm + $w.top.list delete 0 end + puts "${attr} \{${scanTerm}\}" + if {$scanTerm == ""} { + z39.scan scan "${attr} 0" + } else { + z39.scan scan "${attr} \{${scanTerm}\}" + } + show-status {Scan} 1 0 + } if {$toget < 0} { for {set i 0} {$i < $m} {incr i} { set term [lindex [z39.scan scanLine $i] 1] @@ -682,6 +736,7 @@ proc scan-response {attr start toget} { z39.scan numberOfTermsRequested $ntoget } z39.scan preferredPositionInResponse 1 + puts "${attr} \{$q\}" z39.scan scan "${attr} \{$q\}" return } @@ -689,7 +744,7 @@ proc scan-response {attr start toget} { set ntoget [expr - $toget - $m] puts ntoget=$ntoget z39 callback [list scan-response $attr 0 -$ntoget] - set q [string range [$w.top.list get 0] 7 end] + set q [string range [$w.top.list get 0] 8 end] puts "up continue: $q" if {$ntoget > 10} { z39.scan numberOfTermsRequested 10 @@ -698,6 +753,7 @@ proc scan-response {attr start toget} { z39.scan numberOfTermsRequested $ntoget z39.scan preferredPositionInResponse [incr ntoget] } + puts "${attr} \{$q\}" z39.scan scan "${attr} \{$q\}" return } @@ -712,11 +768,12 @@ proc scan-down {attr} { set s [$w.top.list size] if {$scanView > $s} { z39 callback [list scan-response $attr [expr $s - 1] 30] - set q [string range [$w.top.list get [expr $s - 1]] 7 end] + set q [string range [$w.top.list get [expr $s - 1]] 8 end] puts "down: $q" z39.scan numberOfTermsRequested 10 z39.scan preferredPositionInResponse 1 show-status {Scan} 1 0 + puts "${attr} \{$q\}" z39.scan scan "${attr} \{$q\}" return } @@ -729,7 +786,7 @@ proc scan-up {attr} { set w .scan-window if {$scanView < 5} { z39 callback [list scan-response $attr 0 -30] - set q [string range [$w.top.list get 0] 7 end] + set q [string range [$w.top.list get 0] 8 end] puts "up: $q" z39.scan numberOfTermsRequested 10 z39.scan preferredPositionInResponse 11 @@ -751,9 +808,12 @@ proc search-response {} { puts "In search-response" init-title-lines show-status {Ready} 0 1 - show-message "[z39.$setNo resultCount] hits" set setMax [z39.$setNo resultCount] - if {$setMax == 0} { + show-message "${setMax} hits" + set l [format "%-4d %7d" $setNo $setMax] + .top.rset.m add command -label $l \ + -command [list add-title-lines $setNo 10000 1] + if {$setMax <= 0} { set status [z39.$setNo responseStatus] if {[lindex $status 0] == "NSD"} { set code [lindex $status 1] @@ -781,25 +841,35 @@ proc present-more {number} { global setOffset global setMax + puts "setOffset=$setOffset" puts "present-more" if {$setNo == 0} { + puts "setNo=$setNo" return } set max [z39.$setNo resultCount] - if {$max <= $setMax} { + if {$max <= $setOffset} { + puts "max=$max" + puts "setOffset=$setOffset" return } if {$number == ""} { set setMax $max } else { incr setMax $number + if {$setMax > $max} { + set setMax $max + } } z39 callback {present-response} set toGet [expr $setMax - $setOffset + 1] + if {$toGet <= 0} { + return + } if {$toGet > 3} { set toGet 3 - } + } z39.$setNo present $setOffset $toGet show-status {Retrieve} 1 0 } @@ -808,7 +878,15 @@ proc init-title-lines {} { .data.list delete 0 end } +proc title-press {y setno} { + show-full-marc $setno [expr 1 + [.data.list nearest $y]] 0 +} + proc add-title-lines {setno no offset} { + if {$offset == 1} { + .data.list delete 0 end + } + bind .data.list [list title-press %y $setno] for {set i 0} {$i < $no} {incr i} { set o [expr $i + $offset] set type [z39.$setno type $o] @@ -825,7 +903,7 @@ proc add-title-lines {setno no offset} { } .data.list insert end "Error ${err}${add}" } elseif {$type == ""} { - .data.list insert end "empty" + break } } } @@ -1230,17 +1308,17 @@ proc cascade-query-list {} { global queryTypes set i 0 - .top.query.m.slist delete 0 last + .top.options.m.slist delete 0 last foreach n $queryTypes { - .top.query.m.slist add command -label $n \ + .top.options.m.slist add command -label $n \ -command [list query-setup $i] incr i } set i 0 - .top.query.m.clist delete 0 last + .top.options.m.clist delete 0 last foreach n $queryTypes { - .top.query.m.clist add command -label $n \ + .top.options.m.clist add command -label $n \ -command [list query-select $i] incr i } @@ -1704,7 +1782,6 @@ pack .bot -fill x menubutton .top.file -text "File" -underline 0 -menu .top.file.m menu .top.file.m .top.file.m add command -label "Save settings" -command {save-settings} -.top.file.m add command -label "Load Set" -command {load-set} .top.file.m add separator .top.file.m add command -label "Exit" -command {exit-action} .top.file.m add separator @@ -1727,26 +1804,33 @@ menu .top.target.m.clist menu .top.target.m.slist cascade-target-list -menubutton .top.search -text "Search" -underline 0 -menu .top.search.m -menu .top.search.m -.top.search.m add command -label "Database" -command {database-select} -.top.search.m add cascade -label "Query type" -menu .top.search.m.querytype -menu .top.search.m.querytype -.top.search.m.querytype add radiobutton -label "RPN" -.top.search.m.querytype add radiobutton -label "CCL" -.top.search.m add cascade -label "Present" -menu .top.search.m.present -menu .top.search.m.present -.top.search.m.present add command -label "More" -command [list present-more 10] -.top.search.m.present add command -label "All" -command [list present-more {}] -.top.search configure -state disabled - -menubutton .top.query -text "Query" -underline 0 -menu .top.query.m -menu .top.query.m -.top.query.m add cascade -label "Choose" -menu .top.query.m.clist -.top.query.m add command -label "Define" -command {new-query-dialog} -.top.query.m add cascade -label "Edit" -menu .top.query.m.slist -menu .top.query.m.clist -menu .top.query.m.slist +menubutton .top.service -text "Service" -underline 0 -menu .top.service.m +menu .top.service.m +.top.service.m add command -label "Database" -command {database-select} +.top.service.m add cascade -label "Query type" -menu .top.service.m.querytype +menu .top.service.m.querytype +.top.service.m.querytype add radiobutton -label "RPN" +.top.service.m.querytype add radiobutton -label "CCL" +.top.service.m add cascade -label "Present" -menu .top.service.m.present +menu .top.service.m.present +.top.service.m.present add command -label "More" \ + -command [list present-more 10] +.top.service.m.present add command -label "All" \ + -command [list present-more {}] +.top.service configure -state disabled + +menubutton .top.rset -text "Set" -menu .top.rset.m +menu .top.rset.m +.top.rset.m add command -label "Load" -command {load-set} +.top.rset.m add separator + +menubutton .top.options -text "Options" -underline 0 -menu .top.options.m +menu .top.options.m +.top.options.m add cascade -label "Choose query" -menu .top.options.m.clist +.top.options.m add command -label "Define query" -command {new-query-dialog} +.top.options.m add cascade -label "Edit query" -menu .top.options.m.slist +menu .top.options.m.clist +menu .top.options.m.slist cascade-query-list menubutton .top.help -text "Help" -menu .top.help.m @@ -1757,7 +1841,7 @@ menu .top.help.m .top.help.m add command -label "About" \ -command {tkerror "About not available. Sorry"} -pack .top.file .top.target .top.query .top.search -side left +pack .top.file .top.target .top.service .top.rset .top.options -side left pack .top.help -side right index-lines .lines 1 $queryButtonsFind [lindex $queryInfo 0] activate-index @@ -1773,7 +1857,7 @@ button .mid.clear -width 7 -text {Clear} -command index-clear pack .mid.search .mid.scan .mid.present .mid.clear -side left \ -fill y -padx 5 -pady 3 -listbox .data.list -yscrollcommand {.data.scroll set} -font fixed +listbox .data.list -yscrollcommand {.data.scroll set} -font fixed -geometry 20x2 scrollbar .data.scroll -orient vertical -border 1 pack .data.list -side left -fill both -expand yes pack .data.scroll -side right -fill y @@ -1797,12 +1881,7 @@ pack .bot.a.target -side top -anchor nw -padx 2 -pady 2 pack .bot.a.status .bot.a.set .bot.a.message \ -side left -padx 2 -pady 2 -bind .data.list {set indx [.data.list nearest %y] -show-full-marc [incr indx] 0} - ir z39 -z39 options search present scan namedResultSets triggerResourceCtrl -puts [z39 options] show-logo 1