X-Git-Url: http://git.indexdata.com/?p=yaz-moved-to-github.git;a=blobdiff_plain;f=src%2Fzoom-c.c;h=1c67d1d70fb52df9f81a19a3566710c00c48d1a3;hp=3e5c65e1da7e14c19a30eaab7619b49e3ba02b3e;hb=72009188eda06296bb8839ef16de1470ecc2d240;hpb=1b74d7ac0e734e7740dae73ea340d24334960bc5 diff --git a/src/zoom-c.c b/src/zoom-c.c index 3e5c65e..1c67d1d 100644 --- a/src/zoom-c.c +++ b/src/zoom-c.c @@ -2,7 +2,7 @@ * Copyright (C) 1995-2005, Index Data ApS * See the file LICENSE for details. * - * $Id: zoom-c.c,v 1.48 2005-11-01 15:08:02 adam Exp $ + * $Id: zoom-c.c,v 1.53 2005-12-07 16:15:15 mike Exp $ */ /** * \file zoom-c.c @@ -388,6 +388,24 @@ ZOOM_connection_connect(ZOOM_connection c, else c->host_port = xstrdup(host); + if ((val = strchr(c->host_port, '%')) != 0) { + /* We recognise :% for embedded + * authentication. This is slightly hacky syntax, but it's + * hard to get into the comstack code in a + * protocol-independent way. + */ + *(char*)val = '\0'; + char *remainder = xstrdup(val+1); + char *pass = strchr(c->host_port, ':'); + if (pass != 0) { + *pass++ = '\0'; + ZOOM_connection_option_set(c, "user", c->host_port); + ZOOM_connection_option_set(c, "password", pass); + } + xfree(c->host_port); + c->host_port = remainder; + } + ZOOM_options_set(c->options, "host", c->host_port); val = ZOOM_options_get (c->options, "cookie"); @@ -644,17 +662,34 @@ ZOOM_connection_search(ZOOM_connection c, ZOOM_query q) return r; } +/* + * This is the old result-set sorting API, which is maintained only + * for the sake of binary compatibility. There is no reason ever to + * use this rather than ZOOM_resultset_sort1(). + */ ZOOM_API(void) - ZOOM_resultset_sort(ZOOM_resultset r, - const char *sort_type, const char *sort_spec) +ZOOM_resultset_sort(ZOOM_resultset r, + const char *sort_type, const char *sort_spec) +{ + (void) ZOOM_resultset_sort1(r, sort_type, sort_spec); +} + +ZOOM_API(int) +ZOOM_resultset_sort1(ZOOM_resultset r, + const char *sort_type, const char *sort_spec) { ZOOM_connection c = r->connection; ZOOM_task task; + ZOOM_query newq; + + newq = ZOOM_query_create(); + if (ZOOM_query_sortby(newq, sort_spec) < 0) + return -1; yaz_log(log_api, "%p ZOOM_resultset_sort r=%p sort_type=%s sort_spec=%s", r, r, sort_type, sort_spec); if (!c) - return; + return 0; if (c->host_port && c->proto == PROTO_HTTP) { @@ -674,8 +709,7 @@ ZOOM_API(void) ZOOM_resultset_cache_reset(r); task = ZOOM_connection_add_task (c, ZOOM_TASK_SORT); task->u.sort.resultset = r; - task->u.sort.q = ZOOM_query_create(); - ZOOM_query_sortby(task->u.sort.q, sort_spec); + task->u.sort.q = newq; ZOOM_resultset_addref (r); @@ -684,6 +718,8 @@ ZOOM_API(void) while (ZOOM_event (1, &c)) ; } + + return 0; } ZOOM_API(void) @@ -1045,7 +1081,7 @@ static zoom_ret ZOOM_connection_send_init (ZOOM_connection c) ZOOM_options_get(c->options, "implementationName"), odr_prepend(c->odr_out, "ZOOM-C", ireq->implementationName)); - version = odr_strdup(c->odr_out, "$Revision: 1.48 $"); + version = odr_strdup(c->odr_out, "$Revision: 1.53 $"); if (strlen(version) > 10) /* check for unexpanded CVS strings */ version[strlen(version)-2] = '\0'; ireq->implementationVersion = odr_prepend(c->odr_out, @@ -2082,7 +2118,7 @@ static void handle_searchResult(ZOOM_connection c, ZOOM_resultset resultset, if (sr->num) ZOOM_options_set_int( - resultset->options, "SearchResult.size", sr->num); + resultset->options, "searchresult.size", sr->num); for (j = 0; j < sr->num; j++) { @@ -2090,12 +2126,12 @@ static void handle_searchResult(ZOOM_connection c, ZOOM_resultset resultset, ext->u.searchResult1->elements[j]; char pref[80]; - sprintf(pref, "SearchResult.%d", j); + sprintf(pref, "searchresult.%d", j); if (ent->subqueryId) { char opt_name[80]; - sprintf(opt_name, "%s.subqueryId", pref); + sprintf(opt_name, "%s.id", pref); ZOOM_options_set(resultset->options, opt_name, ent->subqueryId); } @@ -2123,7 +2159,7 @@ static void handle_searchResult(ZOOM_connection c, ZOOM_resultset resultset, if (ent->subqueryCount) { char opt_name[80]; - sprintf(opt_name, "%s.subqueryCount", pref); + sprintf(opt_name, "%s.count", pref); ZOOM_options_set_int(resultset->options, opt_name, *ent->subqueryCount); } @@ -3574,6 +3610,14 @@ ZOOM_connection_addinfo (ZOOM_connection c) } ZOOM_API(const char *) +ZOOM_connection_diagset (ZOOM_connection c) +{ + const char *diagset; + ZOOM_connection_error_x (c, 0, 0, &diagset); + return diagset; +} + +ZOOM_API(const char *) ZOOM_diag_str (int error) { switch (error)