X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fzoom-c.c;h=3615ed97e4813d529b42e774508c46f41a15e766;hb=689388c889a644a40ca1f447cc862da009049836;hp=00158ec6175ed80cfa32c94c9350f27aacf8201c;hpb=59aa88eb085c71e191802510804588a4f9edbe9b;p=yaz-moved-to-github.git diff --git a/src/zoom-c.c b/src/zoom-c.c index 00158ec..3615ed9 100644 --- a/src/zoom-c.c +++ b/src/zoom-c.c @@ -70,8 +70,9 @@ void ZOOM_set_dset_error(ZOOM_connection c, int error, } if (addinfo && addinfo2) { - c->addinfo = (char*) xmalloc(strlen(addinfo) + strlen(addinfo2) + 2); + c->addinfo = (char*) xmalloc(strlen(addinfo) + strlen(addinfo2) + 3); strcpy(c->addinfo, addinfo); + strcat(c->addinfo, ": "); strcat(c->addinfo, addinfo2); } else if (addinfo) @@ -266,6 +267,7 @@ ZOOM_API(ZOOM_connection) c->host_port = 0; c->proxy = 0; + c->tproxy = 0; c->charset = c->lang = 0; @@ -388,6 +390,16 @@ ZOOM_API(void) c->proxy = xstrdup(val); } + xfree(c->tproxy); + c->tproxy = 0; + val = ZOOM_options_get(c->options, "tproxy"); + if (val && *val) + { + yaz_log(c->log_details, "%p ZOOM_connection_connect tproxy=%s", c, val); + c->tproxy = xstrdup(val); + } + + xfree(c->charset); c->charset = 0; val = ZOOM_options_get(c->options, "charset"); @@ -590,6 +602,7 @@ ZOOM_API(void) ZOOM_connection_remove_events(c); xfree(c->host_port); xfree(c->proxy); + xfree(c->tproxy); xfree(c->charset); xfree(c->lang); xfree(c->cookie_out); @@ -1044,7 +1057,8 @@ static zoom_ret do_connect_host(ZOOM_connection c, const char *logical_url) if (c->cs) cs_close(c->cs); - c->cs = cs_create_host_proxy(logical_url, 0, &add, c->proxy); + c->cs = cs_create_host_proxy(logical_url, 0, &add, + c->tproxy ? c->tproxy : c->proxy); if (c->cs && c->cs->protocol == PROTO_HTTP) { @@ -1612,6 +1626,8 @@ static void handle_http(ZOOM_connection c, Z_HTTP_Response *hres) c->reconnect_ok = 0; } } + else + c->reconnect_ok = 1; /* if the server closes anyway */ } } #endif @@ -1682,7 +1698,6 @@ static int do_read(ZOOM_connection c) #endif } } - c->reconnect_ok = 0; } return 1; }