<html>
{
-# $Id: search.egw,v 1.7 1995/11/02 16:35:36 adam Exp $
+# $Id: search.egw,v 1.17 1995/11/14 16:01:51 adam Exp $
-proc search-response {sno} {
- global sessionWait
-
- set status [z39.$sno responseStatus]
- if {[lindex $status 0] == "NSD"} {
- z39.$sno nextResultSetPosition 0
- set code [lindex $status 1]
- set msg [lindex $status 2]
- set addinfo [lindex $status 3]
- htmlr {<strong>Error} $code {: } $msg {: } $addinfo { </strong><br>}
- set sessionWait -2
- } else {
- set sessionWait 1
- }
-}
-
-proc ok-response {} {
- global sessionWait
- set sessionWait 1
-}
-
-proc fail-response {} {
- global sessionWait
- set sessionWait -1
-}
-
-proc display-brief {zset no} {
- global env
- global setNo
+proc buttons {setNo setMax startPos after} {
global sessionId
+ global env
+ global hist
- set type [$zset type $no]
- if {$type == "SD"} {
- set err [lindex [$zset diag $no] 1]
- set add [lindex [$zset diag $no] 2]
- if {$add != {}} {
- set add " :${add}"
- }
- htmlr "${no} Error ${err}${add} <br>"
- return
- }
- if {$type != "DB"} {
- return
- }
- html "${no} "
- set rtype [$zset recordType $no]
- if {$rtype == "SUTRS"} {
- html [join [$zset getSutrs $no]]
- htmlr {<br>}
- return
- }
- if {![catch {
- set title [lindex [$zset getMarc $no field 245 * a] 0]
- set year [lindex [$zset getMarc $no field 260 * c] 0]
- } ] } {
- html {<a href="http://} $env(SERVER_NAME) $env(SCRIPT_NAME) /
- html $sessionId {/showfull.egw/} $setNo + $no {"> } $title {</a>}
- html " <i> ${year} </i>"
+ if {$after && $setMax < [z39.$setNo resultCount]} {
+ html "<p>\n"
+ html "<center>\n"
+ html {<a href="http:} $env(SCRIPT_NAME)
+ html / $sessionId {/search.egw/} $setNo + [expr $setMax + 1]
+ html + [expr $setMax + $hist($setNo,maxPresent)]
+ html {"><img src="/gif/darrw.gif"></a>}
+ html "</center>\n"
}
- htmlr {<br>}
-}
-proc display-full {zset no} {
- set type [$zset type $no]
- if {$type == "SD"} {
- set err [lindex [$zset diag $no] 1]
- set add [lindex [$zset diag $no] 2]
- if {$add != {}} {
- set add " :${add}"
- }
- htmlr "<hr> ${no} <br>"
- htmlr "Error ${err}${add} <br>"
- return
- }
- if {$type != "DB"} {
- return
- }
- htmlr "<hr> ${no} <br>"
- set rtype [$zset recordType $no]
- if {$rtype == "SUTRS"} {
- htmlr [join [$zset getSutrs $no]]
- return
- }
- if {[catch {set r [$zset getMarc $no line * * *]}]} {
- htmlr "Unknown record type: $rtype"
- return
+ html "<p>\n"
+ if {$setMax < [z39.$setNo resultCount]} {
+ html {<a href="http:} $env(SCRIPT_NAME)
+ html / $sessionId {/search.egw/} $setNo + [expr $setMax + 1]
+ html + [expr $setMax + $hist($setNo,maxPresent)]
+ html {">Next records</a>} " | \n"
}
- foreach line $r {
- set tag [lindex $line 0]
- set indicator [lindex $line 1]
- set fields [lindex $line 2]
- set l [string length $indicator]
- html "$tag "
- if {$l > 0} {
- for {set i 0} {$i < $l} {incr i} {
- if {[string index $tag $i] == " "} {
- html "_"
- } else {
- html [string index $tag $i]
- }
- }
- }
- foreach field $fields {
- set id [lindex $field 0]
- set data [lindex $field 1]
- if {$id != ""} {
- html " <b>\$$id</b> "
- }
- html $data
- }
- htmlr {<br>}
+ if {$startPos != "" && $startPos != "1"} {
+ html {<a href="http:} $env(SCRIPT_NAME)
+ html / $sessionId {/search.egw/} $setNo
+ html + [expr $startPos - $hist($setNo,maxPresent)]
+ html + [expr $startPos - 1]
+ html {">Previous records</a>} " | \n"
}
-}
+ html {<a href="http:} $env(SCRIPT_NAME)
+ html / $sessionId {/query.egw/} $hist($setNo,host) + $setNo
+ html {">New query</a>} " | \n"
-proc display-rec {from to} {
- global setNo
+ html {<a href="http:} $env(SCRIPT_NAME)
+ html / $sessionId {/targets.egw">New target</a>} "<p>\n"
- while {$from <= $to} {
- display-brief z39.$setNo $from
- incr from
+ if {!$after && $startPos != "" && $startPos != "1"} {
+ html "<center>\n"
+ html {<a href="http:} $env(SCRIPT_NAME)
+ html / $sessionId {/search.egw/} $setNo
+ html + [expr $startPos - $hist($setNo,maxPresent)]
+ html + [expr $startPos - 1]
+ html {"><img src="/gif/uarrw.gif"></a>}
+ html "</center><p>\n"
}
-}
-proc build-query {} {
- global targets
- global t
-
- set op {}
- set q {}
- for {set i 1} {$i < 4} {incr i} {
- set term [wform entry$i]
- if {$term != ""} {
- set field [wform menu$i]
- foreach x [lindex $targets($t) 2] {
- if {[lindex $x 0] == $field} {
- set attr [lindex $x 1]
- }
- }
- switch $op {
- And
- { set q "@and $q ${attr} ${term}" }
- Or
- { set q "@or $q ${attr} ${term}" }
- {And not}
- { set q "@not $q ${attr} ${term}" }
- {}
- { set q "${attr} ${term}" }
- }
- set op [wform logic$i]
- }
- }
- return $q
}
-proc research {setNo oldHost piggy} {
- global hist
+ if {[info commands saveState] == ""} {
+ source z39util.tcl
+ }
global sessionWait
+ global nextSetNo
+ global setNo
+ global hist
- set host $hist($setNo,host)
- if {[catch {z39 failback fail-response}]} {
- ir z39
- }
- if {[catch {set oldHost [z39 connect]}]} {
- set oldHost ""
- }
- z39 callback ok-response
- z39 failback fail-response
- if {$oldHost != $host} {
- catch {z39 disconnect}
+ set setNo [lindex $sessionParms 0]
+ if {[wform menu1] != ""} {
+ set hist($nextSetNo,idAuthentication) $hist($setNo,idAuthentication)
+ set hist($nextSetNo,host) $hist($setNo,host)
+ set setNo $nextSetNo
+ html "using host " $hist($setNo,host) " <br\n"
- html "Connecting to target " $host " <br>\n"
- set sessionWait 0
- if {[catch {z39 connect $host}]} {
- htmlr "Cannot connect to target ${host} <br>"
- htmlr "</body></html>"
+ set query [build-query $hist($setNo,host)]
+ if {"x$query" == "x"} {
+ html "<head><title> WWW/Z39.50 Gateway Search</title>\n<body>\n"
+ displayError "Empty query" \
+ "You must specify at least one search word"
+ html "</body></html>\n"
wabort
- } elseif {$sessionWait == 0} {
- zwait sessionWait
- if {$sessionWait != 1} {
- htmlr "Cannot connect to target ${host} <br>"
- htmlr "</body></html>"
- wabort
- }
}
- set sessionWait 0
- z39 init
- zwait sessionWait
- if {$sessionWait != "1"} {
- htmlr "Cannot initialize with target ${host} <br>"
- htmlr "</body></html>"
- wabort
- }
- }
- if {![catch {z39.$setNo smallSetUpperBound 0}]} {
- return
- }
- ir-set z39.$setNo z39
- eval z39.$setNo databaseNames $hist($setNo,database)
-
- z39.$setNo preferredRecordSyntax USMARC
-
- z39 callback search-response $setNo
- if {$piggy} {
- z39.$setNo largeSetLowerBound 999999
- z39.$setNo smallSetUpperBound 0
- z39.$setNo mediumSetPresentNumber $hist($setNo,maxPresent)
- } else {
- z39.$setNo largeSetLowerBound 2
- z39.$setNo smallSetUpperBound 0
- z39.$setNo mediumSetPresentNumber 0
- }
- set sessionWait 0
- z39.$setNo search $hist($setNo,query)
+ set hist($setNo,query) $query
- zwait sessionWait
- if {$sessionWait != 1} {
- htmlr {</body></html>}
- wabort
- }
-}
+ set hist($setNo,form,menu1) [wform menu1]
+ set hist($setNo,form,menu2) [wform menu2]
+ set hist($setNo,form,menu3) [wform menu3]
- global sessionWait
- global nextSetNo
- global setNo
- global hist
+ set hist($setNo,form,entry1) [wform entry1]
+ set hist($setNo,form,entry2) [wform entry2]
+ set hist($setNo,form,entry3) [wform entry3]
- set oldHost $hist($setNo,host)
+ set hist($setNo,form,logic1) [wform logic1]
+ set hist($setNo,form,logic2) [wform logic2]
- if {[wform menu1] == ""} {
- html "state 1<br>\n"
- set setNo [lindex $sessionParms 0]
- } else {
- html "state 2<br>\n"
- if {![info exists hist($nextSetNo,host)]} {
- set hist($nextSetNo,host) $oldHost
- }
- set setNo $nextSetNo
- html "using host " $hist($setNo,host) " <br\n"
incr nextSetNo
+
+ set host $hist($setNo,host)
+ set databases [lindex $targets($host) 1]
- set hist($setNo,query) [build-query]
set b [wform base]
- if {$b == ""} {
+ if {[wform baseall] != ""} {
+ set hist($setNo,database) $databases
+ } elseif {$b == ""} {
set hist($setNo,database) $databases
} else {
set hist($setNo,database) $b
set host $hist($setNo,host)
set databases [lindex $targets($host) 1]
- htmlr {<head><title> WWW/Z39.50 Gateway Search } $host { </title>}
- htmlr {</head><body>}
- html "<h2> Search result </h2>\n"
- wflush
-
+ html "<head><title> WWW/Z39.50 Gateway Search " $host " </title>\n"
+ html "</head><body>\n"
set startPos [lindex $sessionParms 1]
set endPos [lindex $sessionParms 2]
+ set setMax 0
+ set setOffset 0
if {$startPos == ""} {
- research $setNo $oldHost 1
-
+ if {[z39search $setNo 1 0 B] != "1"} {
+ return
+ }
set r [z39.$setNo resultCount]
- html "<h3> $r hits</h3><br>\n"
- set setOffset [z39.$setNo numberOfRecordsReturned]
- display-rec 1 $setOffset
+ html "<h2> Search result $r hits</h2>\n"
wflush
+ set setOffset [z39.$setNo numberOfRecordsReturned]
+ display-rec 1 $setOffset display-brief 0
incr setOffset
set setMax [z39.$setNo resultCount]
if {$setMax > $hist($setNo,maxPresent)} {
set setMax $hist($setNo,maxPresent)
}
} else {
- research $setNo $oldHost 0
-
+ if {[z39search $setNo 0 0 B] != "1"} {
+ return
+ }
+ set r [z39.$setNo resultCount]
+ html "<h2> Search result $r hits</h2>\n"
+ wflush
set setOffset $startPos
set setMax [z39.$setNo resultCount]
if {$setMax > $endPos} {
set setMax $endPos
}
- }
- set toGet [expr 1 + $setMax - $setOffset]
- while {$toGet > 0} {
- for {set got 0} {$got < $toGet} {incr got} {
- if {[z39.$setNo type [expr $setOffset + $got]] == ""} {
- break
- }
+ if {$setMax > 0} {
+ buttons $setNo $setMax $startPos 0
}
- if {$got < $toGet} {
- set sessionWait 0
- z39.$setNo present $setOffset $toGet
- zwait sessionWait
- if {$sessionWait != "1"} {
- break
- }
- set got [z39.$setNo numberOfRecordsReturned]
- }
- display-rec $setOffset [expr $got + $setOffset - 1]
- set setOffset [expr $got + $setOffset]
- set toGet [expr 1 + $setMax - $setOffset]
- wflush
}
+ if {$setMax > 0} {
+ z39present $setNo 0 $setOffset $setMax display-brief B
+ }
+
+ buttons $setNo $setMax $startPos 1
}
{
html "<hr>\n"
- html "<strong>Debug information</strong><br>\n"
+ html "<h3>Debug information</h3>\n"
html "sessionId: $sessionId <br>\n"
html "sessionParms: $sessionParms <br>\n"
foreach e {SERVER_NAME PATH_INFO SCRIPT_NAME} {
html "target: " $host " <br>\n"
html "databases: " $hist($setNo,database) " <br>\n"
html "selected: " [wform base] " <br>\n"
- html "query: ->" $hist($setNo,query) "<- <br>"
+ html "query: --" $hist($setNo,query) "-- <br>"
html "setNo: " $setNo " <br>\n"
html "nextSetNo: " $nextSetNo " <br>\n"
}
-<hr>
-{
- if {$setMax < [z39.$setNo resultCount]} {
- html {<a href="http://} $env(SERVER_NAME) $env(SCRIPT_NAME)
- html / $sessionId {/search.egw/} $setNo + [expr $setMax + 1]
- html + [expr $setMax + $hist($setNo,maxPresent)] {"> Next </a>} "| \n"
- }
- if {$startPos != ""} {
- html {<a href="http://} $env(SERVER_NAME) $env(SCRIPT_NAME)
- html / $sessionId {/search.egw/} $setNo
- if {[expr $startPos - $hist($setNo,maxPresent)] > 1} {
- html + [expr $startPos - $hist($setNo,maxPresent)]
- html + [expr $startPos - 1]
- }
- html {"> Prev </a>} "| \n"
- }
- html {<a href="http://} $env(SERVER_NAME) $env(SCRIPT_NAME)
- html / $sessionId {/targets.egw"> New target </a>} " | \n"
- html {<a href="http://} $env(SERVER_NAME) $env(SCRIPT_NAME)
- html / $sessionId {/query.egw/} $host + $setNo {"> New query </a>}
-}
</body>
</html>