+ if (req->termListAndStartPoint->term->which == Z_Term_general)
+ logf(LOG_DEBUG, " term: '%.*s'",
+ req->termListAndStartPoint->term->u.general->len,
+ req->termListAndStartPoint->term->u.general->buf);
+ srq.num_bases = req->num_databaseNames;
+ srq.basenames = req->databaseNames;
+ srq.num_entries = *req->numberOfTermsRequested;
+ srq.term = req->termListAndStartPoint;
+ srq.term_position = req->preferredPositionInResponse ?
+ *req->preferredPositionInResponse : 1;
+ if (!(srs = bend_scan(assoc->backend, &srq, 0)))
+ ents.u.nonSurrogateDiagnostics = diagrecs(assoc->proto, 2, 0);
+ else if (srs->errcode)
+ ents.u.nonSurrogateDiagnostics = diagrecs(assoc->proto,
+ srs->errcode, srs->errstring);
+ else
+ {
+ int i;
+ static Z_Entries list;
+
+ if (srs->status == BEND_SCAN_PARTIAL)
+ scanStatus = Z_Scan_partial_5;
+ else
+ scanStatus = Z_Scan_success;
+ ents.which = Z_ListEntries_entries;
+ ents.u.entries = &list;
+ list.entries = tab;
+ for (i = 0; i < srs->num_entries; i++)
+ {
+ Z_Entry *e;
+ Z_TermInfo *t;
+ Odr_oct *o;
+
+ if (i >= SCAN_MAX_ENTRIES)
+ {
+ scanStatus = Z_Scan_partial_4;
+ break;
+ }
+ list.entries[i] = e = odr_malloc(assoc->encode, sizeof(*e));
+ e->which = Z_Entry_termInfo;
+ e->u.termInfo = t = odr_malloc(assoc->encode, sizeof(*t));
+ t->suggestedAttributes = 0;
+ t->alternativeTerm = 0;
+ t->byAttributes = 0;
+ t->globalOccurrences = &srs->entries[i].occurrences;
+ t->term = odr_malloc(assoc->encode, sizeof(*t->term));
+ t->term->which = Z_Term_general;
+ t->term->u.general = o = odr_malloc(assoc->encode,
+ sizeof(Odr_oct));
+ o->buf = odr_malloc(assoc->encode, o->len = o->size =
+ strlen(srs->entries[i].term));
+ memcpy(o->buf, srs->entries[i].term, o->len);
+ logf(LOG_DEBUG, " term #%d: '%s' (%d)", i,
+ srs->entries[i].term, srs->entries[i].occurrences);
+ }
+ list.num_entries = i;
+ res.numberOfEntriesReturned = &list.num_entries;
+ res.positionOfTerm = &srs->term_position;
+ }