</head>
<body>
{
-# $Id: query.egw,v 1.6 1995/10/31 16:56:23 adam Exp $
+# $Id: query.egw,v 1.10 1995/11/08 12:42:17 adam Exp $
+
+ if {[info commands saveState] == ""} {
+ source z39util.tcl
+ }
+
proc fail-response {} {
global sessionWait
set sessionWait -1
set sessionWait 1
}
- global host
- set host $sessionParms
- set databases [lindex $targets($host) 1]
- catch {z39 disconnect}
- set sessionWait 0
- ir z39
- z39 failback fail-response
+ global setNo
+ global nextSetNo
+ global hist
+
+ set host [lindex $sessionParms 0]
+
+ if {[info exists setNo]} {
+ set oldHost $hist($setNo,host)
+ } else {
+ set oldHost ""
+ }
+ if {[catch {set setNo $nextSetNo}]} {
+ set nextSetNo 1
+ set setNo 1
+ }
+ set hist($setNo,host) $host
+ set hist($setNo,idAuthentication) [lindex $targets($host) 3]
+
+ if {[catch {z39 failback fail-response}]} {
+ ir z39
+ }
+
+ html "<h2> Search in " [lindex $targets($host) 0] "</h2>\n"
+
z39 callback ok-response
- if {[catch {z39 connect $host}]} {
- htmlr "Cannot connect to target ${host} <br>"
- htmlr "</body></html>"
- wabort
- } elseif {$sessionWait == 0} {
+ z39 failback fail-response
+ if {$host != $oldHost} {
+ catch {z39 disconnect}
+
+ set sessionWait 0
+ if {[catch {z39 connect $host}]} {
+ html "Cannot connect to target ${host} <br>\n"
+ html "</body></html>\n"
+ wabort
+ } elseif {$sessionWait == 0} {
+ zwait sessionWait
+ if {$sessionWait != 1} {
+ html "Cannot connect to target ${host} <br>\n"
+ html "</body></html>\n"
+ wabort
+ }
+ }
+ set sessionWait 0
+ z39 idAuthentication $hist($setNo,idAuthentication)
+ if {[catch {z39 init}]} {
+ htmlr "Cannot initialize with target ${host} <br>"
+ htmlr "</body></html>"
+ wabort
+ }
zwait sessionWait
- if {$sessionWait != 1} {
- htmlr "Cannot connect to target ${host} <br>"
+ if {$sessionWait != "1"} {
+ htmlr "Cannot initialize with 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
- }
- htmlr {<h2> Search in databases </h2>}
+ set databases [lindex $targets($host) 1]
+
html {<form action="http://} $env(SERVER_NAME) $env(SCRIPT_NAME)
- htmlr / $sessionId {/search.egw/} $host {" method=post>}
+ html / $sessionId {/search.egw/} $setNo {" method=post>} \n
set nodb [llength $databases]
if {$nodb > 1} {
if {$nodb > 2} {
- html {The chosen target supports searching in }
- htmlr {several databases. <br>}
- htmlr {Choose the bases you want to search: <br>}
+ html "The chosen target supports searching in "
+ html "several databases. <br>\n"
+ html "Choose the bases you want to search: <br>\n"
}
set i 0
foreach d $databases {
html {<input type="checkbox" name="base" value="} $d
if {[incr i] > 1} {
- htmlr {"> } $d
+ html {"> } $d \n
} else {
- htmlr {" checked> } $d
+ html {" checked> } $d \n
}
}
- htmlr {<br>}
+ html "<br>\n"
if {$nodb > 2} {
html {<input type="checkbox" name="base" value="}
- htmlr [concat $databases] {"> All <br>}
+ html [concat $databases] {"> All <br>} \n
}
}
}
<hr>
-<strong>Input your search criteria: </strong> <br>
+<h3>Input your search criteria: </h3> <br>
{
set fields [lindex $targets($host) 2]
for {set no 1} {$no < 4} {incr no} {
- htmlr {<select name="menu} $no {">}
+ html {<select name="menu} $no {">} \n
foreach f $fields {
- htmlr {<option> } [lindex $f 0]
+ html {<option> } [lindex $f 0] \n
}
- htmlr </select>
- htmlr {<input type="text" name="entry} $no {" size=30>}
+ html "</select>\n"
+ html {<input type="text" name="entry} $no {" size=30>} \n
if {$no < 3} {
- htmlr {<select name="logic} $no {">}
- htmlr {<option> And}
- htmlr {<option> Or}
- htmlr {<option> And not}
- htmlr {</select>}
+ html {<select name="logic} $no {">} \n
+ html "<option> And\n"
+ html "<option> Or\n"
+ html "<option> And not\n"
+ html "</select>\n"
}
- htmlr <br>
+ html "<br>\n"
}
}
<hr><p>
Alternatively you can enter your query in
<a href="ccl.html"> CCL </a> here: <br>
-<input type=text name="cclentry" size=60> <br>
+<input type=text name="cclentry" size=52> <br>
<hr>
-<strong> Various technical parameters: </strong> <br>
-Max hits: <input type="text" name="hits" value="50" size=3>
+<h3> Various technical parameters: </h3> <br>
+Max hits: <input type="text" name="hits" value="10" size=3>
Records are shown in:
<select name="format">
<option> Long format
<em> This and the following pages are under construction
and will continue to be so until the end of December 1995.</em>
<hr>
-sessionId: {html $sessionId} <br>
-sessionParms: {html $sessionParms}<br>
+
{
+ html {<a href="http://} $env(SERVER_NAME) $env(SCRIPT_NAME)
+ html / $sessionId {/targets.egw"> New target </a>}
+}
+{
+ html "<hr>\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} {
- htmlr $e {: } $env($e) {<br>}
+ html $e {: } $env($e) {<br>} \n
}
+ html "form: " [wform] " <br>\n"
+ html "target: " $host " <br>\n"
+ html "databases: " $databases " <br>\n"
+ html "setNo: " $setNo " <br>\n"
+ html "nextSetNo: " $nextSetNo " <br>\n"
}
-form: {html [wform]} <br>
-target: {html $host} <br>
-databases: {html $databases} <br>
</body></html>
+
+