123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- /*
- * Copyright 1992 by Jutta Degener and Carsten Bormann, Technische
- * Universitaet Berlin. See the accompanying file "COPYRIGHT" for
- * details. THERE IS ABSOLUTELY NO WARRANTY FOR THIS SOFTWARE.
- */
- /*$Header: /tmp_amd/presto/export/kbs/jutta/src/gsm/RCS/sweet.c,v 1.2 1996/07/02 10:15:53 jutta Exp $*/
-
- /* Generate code to unpack a bit array from name:#bits description */
- #include <stdio.h>
- #include "taste.h"
- #include "proto.h"
- void write_code P2((s_spex, n_spex), struct spex * s_spex, int n_spex)
- {
- struct spex * sp = s_spex;
- int bits = 8;
- int vars;
- if (!n_spex) return;
- vars = sp->varsize;
- while (n_spex) {
- if (vars == sp->varsize) {
- printf("\t%s = ", sp->var);
- } else printf("\t%s |= ", sp->var);
- if (vars == bits) {
-
- if (bits == 8) printf( "*c++;\n" );
- else printf( "*c++ & 0x%lX;\n",
- ~(0xfffffffe << (bits - 1)) );
- if (!-- n_spex) break;
- sp++;
- vars = sp->varsize;
- bits = 8;
- } else if (vars < bits) {
- printf( "(*c >> %d) & 0x%lX;\n",
- bits - vars,
- ~(0xfffffffe << (vars - 1)));
- bits -= vars;
- if (!--n_spex) break;
- sp++;
- vars = sp->varsize;
- } else {
- /* vars > bits. We're eating lower-all of c,
- * but we must shift it.
- */
- printf( "(*c++ & 0x%X) << %d;\n",
- ~(0xfffffffe << (bits - 1)),
- vars - bits );
- vars -= bits;
- bits = 8;
- }
- }
- }
|