|
|
1.1 ! root 1: /* bitstr2strb.c - bit string to string of bits */ ! 2: ! 3: #ifndef lint ! 4: static char *rcsid = "$Header: /f/osi/psap/RCS/bitstr2strb.c,v 7.0 89/11/23 22:12:33 mrose Rel $"; ! 5: #endif ! 6: ! 7: /* ! 8: * $Header: /f/osi/psap/RCS/bitstr2strb.c,v 7.0 89/11/23 22:12:33 mrose Rel $ ! 9: * ! 10: * ! 11: * $Log: bitstr2strb.c,v $ ! 12: * Revision 7.0 89/11/23 22:12:33 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: char *bitstr2strb (pe, k) ! 36: PE pe; ! 37: int *k; ! 38: { ! 39: register int i, ! 40: j, ! 41: len, ! 42: bit, ! 43: mask; ! 44: register char *dp; ! 45: char *cp; ! 46: ! 47: if (pe == NULLPE) ! 48: return NULLCP; ! 49: ! 50: *k = len = pe -> pe_nbits; ! 51: if ((cp = dp = calloc (1, (unsigned) (len / 8 + 2))) == NULLCP) ! 52: return NULLCP; ! 53: ! 54: for (bit = i = 0, mask = 1 << (j = 7); i < len; i++) { ! 55: if (bit_test (pe, i)) ! 56: bit |= mask; ! 57: if (j-- == 0) ! 58: *dp++ = bit & 0xff, bit = 0, mask = 1 << (j = 7); ! 59: else ! 60: mask >>= 1; ! 61: } ! 62: if (j != 7) ! 63: *dp = bit & 0xff; ! 64: ! 65: return cp; ! 66: }
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.