X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fzget.c;h=03018f7c0d2e9d5dda21fb04ea125a2d72f2d5a2;hb=5c3d2d2ab097e4bb59ba5718a396b020a2d302c0;hp=402094e970f199c7d531a6d64920122135727695;hpb=317ee76a1bbe9de384aea464c829b8ad627518a2;p=yaz-moved-to-github.git diff --git a/src/zget.c b/src/zget.c index 402094e..03018f7 100644 --- a/src/zget.c +++ b/src/zget.c @@ -2,7 +2,11 @@ * Copyright (c) 1995-2004, Index Data. * See the file LICENSE for details. * - * $Id: zget.c,v 1.4 2004-02-15 07:19:42 adam Exp $ + * $Id: zget.c,v 1.7 2004-12-20 23:35:42 adam Exp $ + */ +/** + * \file zget.c + * \brief Implements Z39.50 package creator utilities */ #include @@ -146,7 +150,7 @@ Z_DeleteResultSetRequest *zget_DeleteResultSetRequest(ODR o) odr_malloc(o, sizeof(*r)); r->referenceId = 0; - r->deleteFunction = odr_intdup(o, Z_DeleteRequest_list); + r->deleteFunction = odr_intdup(o, Z_DeleteResultSetRequest_list); r->num_resultSetList = 0; r->resultSetList = 0; r->otherInfo = 0; @@ -205,7 +209,7 @@ Z_TriggerResourceControlRequest *zget_TriggerResourceControlRequest(ODR o) odr_malloc(o, sizeof(*r)); r->referenceId = 0; - r->requestedAction = odr_intdup(o, Z_TriggerResourceCtrl_resourceReport); + r->requestedAction = odr_intdup(o, Z_TriggerResourceControlRequest_resourceReport); r->prefResourceReportFormat = 0; r->resultSetWanted = 0; r->otherInfo = 0; @@ -245,7 +249,7 @@ Z_AccessControlRequest *zget_AccessControlRequest(ODR o) odr_malloc(o, sizeof(*r)); r->referenceId = 0; - r->which = Z_AccessRequest_simpleForm; + r->which = Z_AccessControlRequest_simpleForm; r->u.simpleForm = 0; r->otherInfo = 0; return r; @@ -257,7 +261,7 @@ Z_AccessControlResponse *zget_AccessControlResponse(ODR o) odr_malloc(o, sizeof(*r)); r->referenceId = 0; - r->which = Z_AccessResponse_simpleForm; + r->which = Z_AccessControlResponse_simpleForm; r->u.simpleForm = 0; r->diagnostic = 0; r->otherInfo = 0; @@ -307,7 +311,7 @@ Z_ResourceReportResponse *zget_ResourceReportResponse(ODR o) odr_malloc(o, sizeof(*r)); r->referenceId = 0; - r->resourceReportStatus = odr_intdup(o, Z_ResourceReportStatus_success); + r->resourceReportStatus = odr_intdup(o, Z_ResourceReportResponse_success); r->resourceReport = 0; r->otherInfo = 0; return r; @@ -330,8 +334,8 @@ Z_SortResponse *zget_SortResponse(ODR o) Z_SortResponse *r = (Z_SortResponse *)odr_malloc(o, sizeof(*r)); r->referenceId = 0; - r->sortStatus = odr_intdup(o, Z_SortStatus_success); - r->resultSetStatus = odr_intdup(o, Z_SortResultSetStatus_empty); + r->sortStatus = odr_intdup(o, Z_SortResponse_success); + r->resultSetStatus = odr_intdup(o, Z_SortResponse_empty); r->diagnostics = 0; r->resultCount = 0; r->otherInfo = 0; @@ -495,3 +499,101 @@ Z_APDU *zget_APDU(ODR o, int which) } return r; } + +Z_DefaultDiagFormat *zget_DefaultDiagFormat(ODR o, int error, + const char *addinfo) +{ + Z_DefaultDiagFormat *dr = (Z_DefaultDiagFormat *) + odr_malloc (o, sizeof(*dr)); + + dr->diagnosticSetId = yaz_oidval_to_z3950oid (o, CLASS_DIAGSET, VAL_BIB1); + dr->condition = odr_intdup(o, error); + dr->which = Z_DefaultDiagFormat_v2Addinfo; + dr->u.v2Addinfo = odr_strdup (o, addinfo ? addinfo : ""); + return dr; +} + +Z_DiagRec *zget_DiagRec(ODR o, int error, const char *addinfo) +{ + Z_DiagRec *dr = (Z_DiagRec*) odr_malloc(o, sizeof(*dr)); + dr->which = Z_DiagRec_defaultFormat; + dr->u.defaultFormat = zget_DefaultDiagFormat(o, error, addinfo); + return dr; +} + +Z_DiagRecs *zget_DiagRecs(ODR o, int error, const char *addinfo) +{ + Z_DiagRecs *drecs = (Z_DiagRecs*) odr_malloc(o, sizeof(*drecs)); + Z_DiagRec **dr = (Z_DiagRec**) odr_malloc(o, sizeof(**dr)); + drecs->diagRecs = dr; + dr[0] = zget_DiagRec(o, error, addinfo); + drecs->num_diagRecs = 1; + return drecs; +} + +Z_NamePlusRecord *zget_surrogateDiagRec(ODR o, const char *dbname, + int error, const char *addinfo) +{ + Z_NamePlusRecord *rec = (Z_NamePlusRecord *) odr_malloc (o, sizeof(*rec)); + Z_DiagRec *drec = (Z_DiagRec *)odr_malloc (o, sizeof(*drec)); + + if (dbname) + rec->databaseName = odr_strdup(o, dbname); + else + rec->databaseName = 0; + rec->which = Z_NamePlusRecord_surrogateDiagnostic; + rec->u.surrogateDiagnostic = drec; + drec->which = Z_DiagRec_defaultFormat; + drec->u.defaultFormat = zget_DefaultDiagFormat(o, error, addinfo); + return rec; +} + +Z_External *zget_init_diagnostics(ODR odr, int error, const char *addinfo) +{ + Z_External *x, *x2; + oident oid; + Z_OtherInformation *u; + Z_OtherInformationUnit *l; + Z_DiagnosticFormat *d; + Z_DiagnosticFormat_s *e; + + x = (Z_External*) odr_malloc(odr, sizeof *x); + x->descriptor = 0; + x->indirect_reference = 0; + oid.proto = PROTO_Z3950; + oid.oclass = CLASS_USERINFO; + oid.value = VAL_USERINFO1; + x->direct_reference = odr_oiddup(odr, oid_getoidbyent(&oid)); + x->which = Z_External_userInfo1; + + u = odr_malloc(odr, sizeof *u); + x->u.userInfo1 = u; + u->num_elements = 1; + u->list = (Z_OtherInformationUnit**) odr_malloc(odr, sizeof *u->list); + u->list[0] = (Z_OtherInformationUnit*) odr_malloc(odr, sizeof *u->list[0]); + l = u->list[0]; + l->category = 0; + l->which = Z_OtherInfo_externallyDefinedInfo; + + x2 = (Z_External*) odr_malloc(odr, sizeof *x); + l->information.externallyDefinedInfo = x2; + x2->descriptor = 0; + x2->indirect_reference = 0; + oid.oclass = CLASS_DIAGSET; + oid.value = VAL_DIAG1; + x2->direct_reference = odr_oiddup(odr, oid_getoidbyent(&oid)); + x2->which = Z_External_diag1; + + d = (Z_DiagnosticFormat*) odr_malloc(odr, sizeof *d); + x2->u.diag1 = d; + d->num = 1; + d->elements = (Z_DiagnosticFormat_s**) odr_malloc (odr, sizeof *d->elements); + d->elements[0] = (Z_DiagnosticFormat_s*) odr_malloc (odr, sizeof *d->elements[0]); + e = d->elements[0]; + + e->which = Z_DiagnosticFormat_s_defaultDiagRec; + e->u.defaultDiagRec = zget_DefaultDiagFormat(odr, error, addinfo); + e->message = 0; + return x; +} +