1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
|
/****************************************************************
* *
* Copyright 2001, 2004 Sanchez Computer Associates, Inc. *
* *
* This source code contains the intellectual property *
* of its copyright holder(s), and is made available *
* under a license. If you do not know the terms of *
* the license, please stop and do not read further. *
* *
****************************************************************/
/*
* omi_prc_setp.c ---
*
* Process a SET PIECE request.
*
*/
#ifndef lint
static char rcsid[] = "$Header:$";
#endif
#include "mdef.h"
#include "omi.h"
#include "error.h"
int
omi_prc_setp(cptr, xend, buff, bend)
omi_conn *cptr;
char *xend;
char *buff;
char *bend;
{
int rv;
omi_si replicate;
omi_li len;
char *gdptr;
omi_li start;
omi_li end;
omi_si dllen;
char *dlptr;
/* Replicate flag */
OMI_SI_READ(&replicate, cptr->xptr);
/* Global Ref */
OMI_LI_READ(&len, cptr->xptr);
/* Condition handler for DBMS operations */
ESTABLISH_RET(omi_dbms_ch, -1); /* any return value to signify error return */
rv = omi_gvextnam(cptr, len.value, cptr->xptr);
/* If true, there was an error finding the global reference in the DBMS */
if (rv < 0) {
REVERT;
return rv;
}
cptr->xptr += len.value;
/* Global Data */
OMI_LI_READ(&len, cptr->xptr);
gdptr = cptr->xptr;
cptr->xptr += len.value;
/* Start piece */
OMI_LI_READ(&start, cptr->xptr);
/* End piece */
OMI_LI_READ(&end, cptr->xptr);
/* Delimiter */
OMI_SI_READ(&dllen, cptr->xptr);
dlptr = cptr->xptr;
/* Bounds checking */
if (cptr->xptr > xend) {
REVERT;
return -OMI_ER_PR_INVMSGFMT;
}
/* XXX $PIECE */
REVERT;
/* The response contains only a header */
return 0;
}
|