projects
/
yaz-moved-to-github.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add odr_setprint_noclose
[yaz-moved-to-github.git]
/
src
/
zoom-c.c
diff --git
a/src/zoom-c.c
b/src/zoom-c.c
index
1bbac7e
..
da0d867
100644
(file)
--- a/
src/zoom-c.c
+++ b/
src/zoom-c.c
@@
-1064,7
+1064,7
@@
static zoom_ret do_connect_host(ZOOM_connection c, const char *logical_url)
if (c->cs)
cs_close(c->cs);
if (c->cs)
cs_close(c->cs);
- c->cs = cs_create_host_proxy(logical_url, 0, &add,
+ c->cs = cs_create_host_proxy(logical_url, CS_FLAGS_DNS_NO_BLOCK, &add,
c->tproxy ? c->tproxy : c->proxy);
if (c->cs && c->cs->protocol == PROTO_HTTP)
c->tproxy ? c->tproxy : c->proxy);
if (c->cs && c->cs->protocol == PROTO_HTTP)
@@
-1563,6
+1563,7
@@
static void handle_http(ZOOM_connection c, Z_HTTP_Response *hres)
location, &host_change);
if (do_connect_host(c, location) == zoom_complete)
return; /* connect failed.. */
location, &host_change);
if (do_connect_host(c, location) == zoom_complete)
return; /* connect failed.. */
+ cs_rcvconnect(c->cs);
send_HTTP_redirect(c, location);
return;
}
send_HTTP_redirect(c, location);
return;
}
@@
-1960,7
+1961,7
@@
static void ZOOM_connection_do_io(ZOOM_connection c, int mask)
if (c->cs->io_pending & CS_WANT_READ)
mask += ZOOM_SELECT_READ;
ZOOM_connection_set_mask(c, mask);
if (c->cs->io_pending & CS_WANT_READ)
mask += ZOOM_SELECT_READ;
ZOOM_connection_set_mask(c, mask);
- event = ZOOM_Event_create(ZOOM_EVENT_NONE);
+ event = ZOOM_Event_create(ZOOM_EVENT_CONNECT);
ZOOM_connection_put_event(c, event);
}
else if (ret == 0)
ZOOM_connection_put_event(c, event);
}
else if (ret == 0)
@@
-1973,9
+1974,11
@@
static void ZOOM_connection_do_io(ZOOM_connection c, int mask)
else
{
/* no init request for SRW .. */
else
{
/* no init request for SRW .. */
- assert(c->tasks->which == ZOOM_TASK_CONNECT);
- ZOOM_connection_remove_task(c);
- ZOOM_connection_set_mask(c, 0);
+ if (c->tasks->which == ZOOM_TASK_CONNECT)
+ {
+ ZOOM_connection_remove_task(c);
+ ZOOM_connection_set_mask(c, 0);
+ }
ZOOM_connection_exec_task(c);
}
c->state = STATE_ESTABLISHED;
ZOOM_connection_exec_task(c);
}
c->state = STATE_ESTABLISHED;