Annotation of 43BSDReno/contrib/isode-beta/psap/obj2prim.c, revision 1.1

1.1     ! root        1: /* obj2prim.c - object identifier to presentation element */
        !             2: 
        !             3: #ifndef        lint
        !             4: static char *rcsid = "$Header: /f/osi/psap/RCS/obj2prim.c,v 7.0 89/11/23 22:12:46 mrose Rel $";
        !             5: #endif
        !             6: 
        !             7: /* 
        !             8:  * $Header: /f/osi/psap/RCS/obj2prim.c,v 7.0 89/11/23 22:12:46 mrose Rel $
        !             9:  *
        !            10:  *
        !            11:  * $Log:       obj2prim.c,v $
        !            12:  * Revision 7.0  89/11/23  22:12:46  mrose
        !            13:  * Release 6.0
        !            14:  * 
        !            15:  */
        !            16: 
        !            17: /*
        !            18:  *                               NOTICE
        !            19:  *
        !            20:  *    Acquisition, use, and distribution of this module and related
        !            21:  *    materials are subject to the restrictions of a license agreement.
        !            22:  *    Consult the Preface in the User's Manual for the full terms of
        !            23:  *    this agreement.
        !            24:  *
        !            25:  */
        !            26: 
        !            27: 
        !            28: /* LINTLIBRARY */
        !            29: 
        !            30: #include <stdio.h>
        !            31: #include "psap.h"
        !            32: 
        !            33: /*  */
        !            34: 
        !            35: PE     obj2prim (o, class, id)
        !            36: register OID   o;
        !            37: PElementClass  class;
        !            38: PElementID     id;
        !            39: {
        !            40:     register int    i,
        !            41:                    m,
        !            42:                    n,
        !            43:                   *mp,
        !            44:                   *np;
        !            45:     register unsigned int j,
        !            46:                         *ip;
        !            47:     register PElementData dp,
        !            48:                          ep;
        !            49:     register PE            pe;
        !            50: 
        !            51:     if (o == NULLOID || o -> oid_nelem <= 1)
        !            52:        return NULLPE;
        !            53: 
        !            54:     if ((pe = pe_alloc (class, PE_FORM_PRIM, id)) == NULLPE)
        !            55:        return NULLPE;
        !            56: 
        !            57:     if ((np = (int *) malloc ((unsigned) (o -> oid_nelem) * sizeof *np))
        !            58:            == NULL) {
        !            59:        pe_free (pe);
        !            60:        return NULLPE;
        !            61:     }
        !            62: 
        !            63:     for (i = n = 0, ip = o -> oid_elements, mp = np;
        !            64:            i < o -> oid_nelem;
        !            65:            i++, ip++) {
        !            66:        if (ip == o -> oid_elements)
        !            67:            j = *ip++ * 40, i++, j+= *ip;
        !            68:        else
        !            69:            j = *ip;
        !            70:        m = 0;
        !            71:        do {
        !            72:            m++;
        !            73:            j >>= 7;
        !            74:        }
        !            75:        while (j);
        !            76:        n += (*mp++ = m);
        !            77:     }
        !            78: 
        !            79:     if ((pe -> pe_prim = PEDalloc (pe -> pe_len = n)) == NULLPED) {
        !            80:        free ((char *) np);
        !            81:        pe_free (pe);
        !            82:        return NULLPE;
        !            83:     }
        !            84: 
        !            85:     dp = pe -> pe_prim; 
        !            86:     for (i = 0, ip = o -> oid_elements, mp = np;
        !            87:            i < o -> oid_nelem;
        !            88:            i++, ip++) {
        !            89:        if (ip == o -> oid_elements)
        !            90:            j = *ip++ * 40, i++, j += *ip;
        !            91:        else
        !            92:            j = *ip;
        !            93: 
        !            94:        ep = dp + (m = *mp++) - 1;
        !            95:        for (dp = ep; m-- > 0; j >>= 7)
        !            96:            *dp-- = (j & 0x7f) | 0x80;
        !            97:        *ep &= ~0x80;
        !            98:        dp = ep + 1;
        !            99:     }
        !           100: 
        !           101:     free ((char *) np);
        !           102: 
        !           103:     return pe;
        !           104: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.