|
|
BSD 4.3reno
/* prim2num.c - presentation element to integer */
#ifndef lint
static char *rcsid = "$Header: /var/lib/cvsd/repos/CSRG/43BSDReno/contrib/isode-beta/psap/prim2num.c,v 1.1.1.1 2018/04/24 16:12:56 root Exp $";
#endif
/*
* $Header: /var/lib/cvsd/repos/CSRG/43BSDReno/contrib/isode-beta/psap/prim2num.c,v 1.1.1.1 2018/04/24 16:12:56 root Exp $
*
*
* $Log: prim2num.c,v $
* Revision 1.1.1.1 2018/04/24 16:12:56 root
* BSD 4.3reno
*
* Revision 7.0 89/11/23 22:13:11 mrose
* Release 6.0
*
*/
/*
* NOTICE
*
* Acquisition, use, and distribution of this module and related
* materials are subject to the restrictions of a license agreement.
* Consult the Preface in the User's Manual for the full terms of
* this agreement.
*
*/
/* LINTLIBRARY */
#include <stdio.h>
#include "psap.h"
/* */
integer prim2num (pe)
register PE pe;
{
register integer i;
register PElementData dp,
ep;
if (pe -> pe_form != PE_FORM_PRIM || pe -> pe_prim == NULLPED)
return pe_seterr (pe, PE_ERR_PRIM, NOTOK);
if (pe -> pe_len > sizeof (i))
return pe_seterr (pe, PE_ERR_OVER, NOTOK);
pe -> pe_errno = PE_ERR_NONE;/* in case integer is NOTOK-valued */
i = (*(dp = pe -> pe_prim) & 0x80) ? (-1) : 0;
for (ep = dp + pe -> pe_len; dp < ep;)
i = (i << 8) | (*dp++ & 0xff);
return i;
}
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.