X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fyaz-z-server-update.cpp;h=a6f2d1a6c67b6b042e0965966b5789ec6c956dba;hb=805b4fdf7b70b0e9b298064f24ceff0c1d38e05b;hp=0b1d70e3fa7be40d1888f34ab3d18449c8477bf8;hpb=4c758111f1ff5a815888f70a4c4335ab149f5608;p=yazpp-moved-to-github.git diff --git a/src/yaz-z-server-update.cpp b/src/yaz-z-server-update.cpp index 0b1d70e..a6f2d1a 100644 --- a/src/yaz-z-server-update.cpp +++ b/src/yaz-z-server-update.cpp @@ -1,48 +1,62 @@ -/* - * Copyright (c) 2000-2003, Index Data. +/* This file is part of the yazpp toolkit. + * Copyright (C) 1998-2013 Index Data and Mike Taylor * See the file LICENSE for details. - * - * $Id: yaz-z-server-update.cpp,v 1.6 2004-11-30 21:10:31 adam Exp $ */ -#include -#include +#if HAVE_CONFIG_H +#include +#endif +#include +#include + +using namespace yazpp_1; -int Yaz_Facility_Update::init(Yaz_Z_Server *s, Z_InitRequest *initRequest, - Z_InitResponse *initResponse) +int Yaz_Facility_Update::init(Z_Server *s, Z_InitRequest *initRequest, + Z_InitResponse *initResponse) { Z_Options *req = initRequest->options; Z_Options *res = initResponse->options; - + if (ODR_MASK_GET(req, Z_Options_extendedServices)) - ODR_MASK_SET(res, Z_Options_extendedServices); + ODR_MASK_SET(res, Z_Options_extendedServices); return 1; } -int Yaz_Facility_Update::recv(Yaz_Z_Server *s, Z_APDU *apdu_request) -{ +int Yaz_Facility_Update::recv(Z_Server *s, Z_APDU *apdu_request) +{ Z_APDU *apdu_response; if (apdu_request->which != Z_APDU_extendedServicesRequest) - return 0; + return 0; Z_ExtendedServicesRequest *req = apdu_request->u.extendedServicesRequest; if (req->taskSpecificParameters && req->taskSpecificParameters->which == Z_External_update) { - apdu_response = s->create_Z_PDU(Z_APDU_extendedServicesResponse); - update_service(req, req->taskSpecificParameters->u.update, - apdu_response->u.extendedServicesResponse); - s->transfer_referenceId(apdu_request, apdu_response); - s->send_Z_PDU(apdu_response, 0); + apdu_response = s->create_Z_PDU(Z_APDU_extendedServicesResponse); + update_service(req, req->taskSpecificParameters->u.update, + apdu_response->u.extendedServicesResponse); + s->transfer_referenceId(apdu_request, apdu_response); + s->send_Z_PDU(apdu_response, 0); + return 1; } else if (req->taskSpecificParameters && - req->taskSpecificParameters->which == Z_External_update0) + req->taskSpecificParameters->which == Z_External_update0) { - apdu_response = s->create_Z_PDU(Z_APDU_extendedServicesResponse); - update_service0 (req, req->taskSpecificParameters->u.update0, - apdu_response->u.extendedServicesResponse); - s->transfer_referenceId(apdu_request, apdu_response); - s->send_Z_PDU(apdu_response, 0); + apdu_response = s->create_Z_PDU(Z_APDU_extendedServicesResponse); + update_service0 (req, req->taskSpecificParameters->u.update0, + apdu_response->u.extendedServicesResponse); + s->transfer_referenceId(apdu_request, apdu_response); + s->send_Z_PDU(apdu_response, 0); + return 1; } - return 1; + return 0; } +/* + * Local variables: + * c-basic-offset: 4 + * c-file-style: "Stroustrup" + * indent-tabs-mode: nil + * End: + * vim: shiftwidth=4 tabstop=8 expandtab + */ +