|
|
Initial revision
/* obj2prim.c - object identifier to presentation element */
#ifndef lint
static char *rcsid = "$Header: /var/lib/cvsd/repos/CSRG/43BSDReno/contrib/isode-beta/psap/obj2prim.c,v 1.1 2018/04/24 16:12:56 root Exp $";
#endif
/*
* $Header: /var/lib/cvsd/repos/CSRG/43BSDReno/contrib/isode-beta/psap/obj2prim.c,v 1.1 2018/04/24 16:12:56 root Exp $
*
*
* $Log: obj2prim.c,v $
* Revision 1.1 2018/04/24 16:12:56 root
* Initial revision
*
* Revision 7.0 89/11/23 22:12:46 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"
/* */
PE obj2prim (o, class, id)
register OID o;
PElementClass class;
PElementID id;
{
register int i,
m,
n,
*mp,
*np;
register unsigned int j,
*ip;
register PElementData dp,
ep;
register PE pe;
if (o == NULLOID || o -> oid_nelem <= 1)
return NULLPE;
if ((pe = pe_alloc (class, PE_FORM_PRIM, id)) == NULLPE)
return NULLPE;
if ((np = (int *) malloc ((unsigned) (o -> oid_nelem) * sizeof *np))
== NULL) {
pe_free (pe);
return NULLPE;
}
for (i = n = 0, ip = o -> oid_elements, mp = np;
i < o -> oid_nelem;
i++, ip++) {
if (ip == o -> oid_elements)
j = *ip++ * 40, i++, j+= *ip;
else
j = *ip;
m = 0;
do {
m++;
j >>= 7;
}
while (j);
n += (*mp++ = m);
}
if ((pe -> pe_prim = PEDalloc (pe -> pe_len = n)) == NULLPED) {
free ((char *) np);
pe_free (pe);
return NULLPE;
}
dp = pe -> pe_prim;
for (i = 0, ip = o -> oid_elements, mp = np;
i < o -> oid_nelem;
i++, ip++) {
if (ip == o -> oid_elements)
j = *ip++ * 40, i++, j += *ip;
else
j = *ip;
ep = dp + (m = *mp++) - 1;
for (dp = ep; m-- > 0; j >>= 7)
*dp-- = (j & 0x7f) | 0x80;
*ep &= ~0x80;
dp = ep + 1;
}
free ((char *) np);
return pe;
}
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.