X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=www%2Fsearch.egw;h=fd25d08ff8236d9404a0774351ee919a70b0e604;hb=a61ad0378b93e99e362a1d92c33d701dbf103eba;hp=0b2c02c10b72536c10c885b307643f11cf24caaa;hpb=949f8c4efedfe6d191264853690c84f527e1790b;p=egate.git diff --git a/www/search.egw b/www/search.egw index 0b2c02c..fd25d08 100644 --- a/www/search.egw +++ b/www/search.egw @@ -1,349 +1,325 @@ { -# $Id: search.egw,v 1.6 1995/11/01 16:15:45 adam Exp $ +# $Id: search.egw,v 1.38 1996/03/13 14:07:31 adam Exp $ -proc search-response {sno} { +proc start-scan {scanNo targetNo cache dir initSet} { + global sessionId + global sessionParms global sessionWait + global setNo + global hist + global targets + global nextSetNo + global env + global useIcons + global debug - 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 {Error} $code {: } $msg {: } $addinfo {
} - set sessionWait -2 - } else { - set sessionWait 1 - } -} - -proc ok-response {} { - global sessionWait - set sessionWait 1 -} + set host $hist($setNo,$targetNo,host) -proc fail-response {} { - global sessionWait - set sessionWait -1 -} + html " WWW/Z39.50 Gateway Scan " [splitHostSpec $host] + html " \n" + html "\n" -proc display-brief {zset no} { - global env - global setNo - global sessionId + set useIcons 1 + button-main - 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}
" - return - } - if {$type != "DB"} { - return - } - html "${no} " - set rtype [$zset recordType $no] - if {$rtype == "SUTRS"} { - html [join [$zset getSutrs $no]] - htmlr {
} - return - } - if {![catch { - set title [lindex [$zset getMarc $no field 245 * a] 0] - set year [lindex [$zset getMarc $no field 260 * c] 0] - } ] } { - html { } $title {} - html " ${year} " + if {$dir == "b"} { + set lines 20 + set pos 20 + } elseif {$dir == "f"} { + set lines 20 + set pos 1 + } else { + set lines 20 + set pos 10 } - htmlr {
} -} - -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}" + if {$hist($setNo,$scanNo,scanTerm) != ""} { + if {[z39scan $setNo $scanNo 0 $lines $pos $cache] != "1"} { + button-new-query $setNo + egw_log debug "z39_scan failed" + return } - htmlr "
${no}
" - htmlr "Error ${err}${add}
" - return - } - if {$type != "DB"} { - return - } - htmlr "
${no}
" - 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 - } - 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] - } - } + html {} + if {$useIcons} { + html {} + } else { + html {Previous Terms | } } - foreach field $fields { - set id [lindex $field 0] - set data [lindex $field 1] - if {$id != ""} { - html " \$$id " - } - html $data + + html {} + if {$useIcons} { + html {} + } else { + html {Next Terms | } } - htmlr {
} + html {} } -} + button-new-query $setNo -proc display-rec {from to} { - global setNo + set databases [splitDatabaseSpec $host] - while {$from <= $to} { - display-brief z39.$setNo $from - incr from + if {$initSet == ""} { + set databaseDefault [lindex $databases 0] + set oSetNo 0 + } else { + set oSetNo $initSet + set databaseDefault $hist($oSetNo,$targetNo,database) } -} - -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}" } + + html {
} \n + set nodb [llength $databases] + if {$nodb > 1} { + if {$nodb > 2} { + html "Databases:
\n" + } + set i 0 + foreach d $databases { + html { } $d \n + } else { + html {" checked> } $d \n } - set op [wform logic$i] + } + html "
\n" + if {$nodb > 2} { + html { All
} \n } } - return $q -} - -proc research {setNo oldHost piggy} { - global hist - global sessionWait - - set host $hist($setNo,host) - if {[catch {z39 failback fail-response}]} { - ir z39 + html "Input your scan criteria:
\n" + set fields [lindex $targets($host) 2] + set no 1 + html {\n" + html { } + html {} + html "\n" + html {

} + + set useIcons 0 + if {$hist($setNo,$scanNo,scanTerm) == ""} { + button-main + button-new-query $setNo return } - ir-set z39.$setNo z39 - eval z39.$setNo databaseNames $hist($setNo,database) - z39.$setNo preferredRecordSyntax USMARC + html "

\n" + display-scan $setNo $scanNo 0 + html "

\n" + + button-main + + html {} + if {$useIcons} { + html {} + } else { + html {Previous Terms | } + } - z39 callback search-response $setNo - if {$piggy} { - z39.$setNo largeSetLowerBound 999999 - z39.$setNo smallSetUpperBound 0 - z39.$setNo mediumSetPresentNumber $hist($setNo,maxPresent) + html {} + if {$useIcons} { + html {} } else { - z39.$setNo largeSetLowerBound 2 - z39.$setNo smallSetUpperBound 0 - z39.$setNo mediumSetPresentNumber 0 + html {Next Terms | } } - set sessionWait 0 - z39.$setNo search $hist($setNo,query) + html {} + button-new-query $setNo - zwait sessionWait - if {$sessionWait != 1} { - htmlr {} - wabort + if {!$debug} return + html "


\n" + html "

Debug information

\n" + html "sessionId: $sessionId
\n" + html "sessionParms: $sessionParms
\n" + foreach e {SERVER_NAME PATH_INFO SCRIPT_NAME} { + html $e {: } $env($e) {
} \n } + html "form: " [egw_form] "
\n" + html "databases: " $hist($setNo,$targetNo,database) "
\n" + html "selected: " [egw_form base] "
\n" + html "setNo: " $setNo "
\n" + html "nextSetNo: " $nextSetNo "
\n" } + if {[info commands saveState] == ""} { + source z39util.tcl + } global sessionWait global nextSetNo global setNo global hist - set oldHost $hist($setNo,host) + set setNo [lindex $sessionParms 0] + set targetNo [lindex $sessionParms 1] + set startPos [lindex $sessionParms 2] + set endPos [lindex $sessionParms 3] - if {[wform menu1] == ""} { - set setNo [lindex $sessionParms 0] - } else { - if {![info exists hist($nextSetNo,host)]} { - set hist($nextSetNo,host) $oldHost - } - set setNo $nextSetNo - incr nextSetNo + if {[egw_form] != ""} { + set hist($nextSetNo,$targetNo,idAuthentication) \ + $hist($setNo,$targetNo,idAuthentication) + set hist($nextSetNo,$targetNo,host) \ + $hist($setNo,$targetNo,host) - set hist($setNo,query) [build-query] - set b [wform base] - if {$b == ""} { - set hist($setNo,database) $databases + if {$nextSetNo == $setNo} { + set setNo $nextSetNo + incr nextSetNo } else { - set hist($setNo,database) $b - } - set hist($setNo,maxPresent) [wform hits] - if {$hist($setNo,maxPresent) == ""} { - set hist($setNo,maxPresent) 30 + catch {unset hist($setNo,$targetNo,hits)} } - } - set host $hist($setNo,host) - set databases [lindex $targets($host) 1] + set hist($setNo,scan) 0 - htmlr { WWW/Z39.50 Gateway Search } $host { } - htmlr {} - html "

Search result

\n" - wflush + set hist($setNo,form,menu1) [egw_form menu1] + set hist($setNo,form,menu2) [egw_form menu2] + set hist($setNo,form,menu3) [egw_form menu3] + set hist($setNo,form,entry1) [egw_form entry1] + set hist($setNo,form,entry2) [egw_form entry2] + set hist($setNo,form,entry3) [egw_form entry3] - set startPos [lindex $sessionParms 1] - set endPos [lindex $sessionParms 2] - if {$startPos == ""} { - research $setNo $oldHost 1 + set hist($setNo,form,logic1) [egw_form logic1] + set hist($setNo,form,logic2) [egw_form logic2] + set hist($setNo,form,logic3) {} + + set host $hist($setNo,0,host) - set r [z39.$setNo resultCount] - html "

$r hits


\n" - set setOffset [z39.$setNo numberOfRecordsReturned] - display-rec 1 $setOffset - wflush - incr setOffset - set setMax [z39.$setNo resultCount] - if {$setMax > $hist($setNo,maxPresent)} { - set setMax $hist($setNo,maxPresent) - } - } else { - research $setNo $oldHost 0 + set databases [splitDatabaseSpec $host] - set setOffset $startPos - set setMax [z39.$setNo resultCount] - if {$setMax > $endPos} { - set setMax $endPos + set b [egw_form base] + if {[egw_form baseall] != ""} { + set hist($setNo,$targetNo,database) $databases + } elseif {$b == ""} { + set hist($setNo,$targetNo,database) $databases + } else { + set hist($setNo,$targetNo,database) $b } - } - 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 + set hist($setNo,maxPresent) [egw_form hits] + if {$hist($setNo,maxPresent) == ""} { + set hist($setNo,maxPresent) 30 + } + set hist($setNo,format) brief + set hist($setNo,sort) server + + set i [lindex $sessionParms 2] + if {[string length $i] == 0} { + for {set j 1} {$j <= 3} {incr j} { + if {[egw_form scan$j] != ""} { + set i $j + break + } } } - if {$got < $toGet} { - set sessionWait 0 - z39.$setNo present $setOffset $toGet - zwait sessionWait - if {$sessionWait != "1"} { - break + if {[string length $i] != 0} { + set scanNo 1000 + set hist($setNo,scan) $i + set termPlusAttr [build-scan $hist($setNo,0,host) $i] + set hist($setNo,$scanNo,scanTerm) [lindex $termPlusAttr 0] + set hist($setNo,scanAttr) [lindex $termPlusAttr 1] + start-scan $scanNo $targetNo 0 {} $setNo + html "\n" + egw_abort + return + } + set query [build-query $hist($setNo,0,host) 3] + if {[string length $query] == 0} { + html " WWW/Z39.50 Gateway Search\n\n" + displayError "Empty query" \ + "You must specify at least one search word" + html "\n" + egw_abort + } + set hist($setNo,0,query) $query + } elseif {[lindex $sessionParms 2] == "hyper"} { + egw_log debug "hyper search" + set hist($nextSetNo,$targetNo,idAuthentication) \ + $hist($setNo,$targetNo,idAuthentication) + set hist($nextSetNo,$targetNo,host) \ + $hist($setNo,$targetNo,host) + set hist($nextSetNo,$targetNo,database) \ + $hist($setNo,$targetNo,database) + + if {$nextSetNo == $setNo} { + set setNo $nextSetNo + incr nextSetNo + } else { + catch {unset hist($setNo,$targetNo,hits)} + } + set hist($setNo,scan) 0 + set hist($setNo,$targetNo,query) \ + "$hist($setNo,scanAttr) \"[lindex $sessionParms 3]\"" + egw_log debug "hyper databases: $hist($setNo,$targetNo,database)" + set hist($setNo,form,entry1) [lindex $sessionParms 3] + set startPos "" + } elseif {[lindex $sessionParms 2] == "scan"} { + egw_log debug "star scan" + set scanNo 1000 + set hist($setNo,$scanNo,scanTerm) {} + start-scan $scanNo $targetNo 0 {} {} + html "\n" + egw_abort + } else { + if {![info exists hist($setNo,scan)]} return + if {$hist($setNo,scan) > 0} { + set scanNo [lindex $sessionParms 2] + set dir [lindex $sessionParms 3] + if {$scanNo == ""} { + set scanNo 1000 } - set got [z39.$setNo numberOfRecordsReturned] + start-scan $scanNo $targetNo 1 $dir $setNo + html "\n" + egw_abort } - display-rec $setOffset [expr $got + $setOffset - 1] - set setOffset [expr $got + $setOffset] - set toGet [expr 1 + $setMax - $setOffset] - wflush } -} + set host $hist($setNo,$targetNo,host) + + html " WWW/Z39.50 Gateway Search " [splitHostSpec $host] + html " \n" + html "\n" + display-result-set-s $setNo $targetNo $startPos $endPos +} { + global debug + if {!$debug} return html "
\n" - html "Debug information
\n" + html "

Debug information

\n" html "sessionId: $sessionId
\n" html "sessionParms: $sessionParms
\n" - foreach e {SERVER_NAME PATH_INFO SCRIPT_NAME} { - html $e {: } $env($e) {
} \n + foreach n [array names env] { + html "env($n) = " $env($n) "
\n" } - html "form: " [wform] "
\n" - html "target: " $host "
\n" - html "databases: " $hist($setNo,database) "
\n" - html "selected: " [wform base] "
\n" - html "query: ->" $hist($setNo,query) "<-
" + html "form: " [egw_form] "
\n" + html "databases: " $hist($setNo,$targetNo,database) "
\n" + html "selected: " [egw_form base] "
\n" + html "query: --" $hist($setNo,$targetNo,query) "--
" html "setNo: " $setNo "
\n" html "nextSetNo: " $nextSetNo "
\n" } - -
-{ - if {$setMax < [z39.$setNo resultCount]} { - html { Next } "| \n" - } - if {$startPos != ""} { - html { Prev } "| \n" - } - html { New target } " | \n" - html { New query } -}