#include <stdlib.h>
#include <unistd.h>
#include <stdio.h>
#include <locale.h>
#include "hash.h"
#include "huff.h"
int decode(long, long *);
int hindex[NI];
unsigned *table;
unsigned wp;
int bp;
#define U (BYTE*sizeof (unsigned))
#define L (BYTE*sizeof (long))
static long
fetch(void)
{
long w1;
long y = 0;
int empty = L;
int i = bp;
int tp = wp;
while (empty >= i) {
empty -= i;
i = U;
y |= (long)table[tp++] << empty;
}
if (empty > 0)
y |= table[tp]>>i-empty;
i = decode((y >> 1) &
(((unsigned long)1 << (BYTE * sizeof (y) - 1)) - 1), &w1);
bp -= i;
while (bp <= 0) {
bp += U;
wp++;
}
return (w1);
}
int
main(int argc, char **argv)
{
int i;
long v;
long a;
(void) setlocale(LC_ALL, "");
#if !defined(TEXT_DOMAIN)
#define TEXT_DOMAIN "SYS_TEST"
#endif
(void) textdomain(TEXT_DOMAIN);
(void) rhuff(stdin);
(void) fread((char *)hindex, sizeof (*hindex), NI, stdin);
table = (unsigned *)malloc(hindex[NI-1]*sizeof (*table));
(void) fread((char *)table, sizeof (*table), hindex[NI-1], stdin);
for (i = 0; i < NI-1; i++) {
bp = U;
v = (long)i<<(HASHWIDTH-INDEXWIDTH);
for (wp = hindex[i]; wp < hindex[i+1]; ) {
if (wp == hindex[i] && bp == U)
a = fetch();
else {
a = fetch();
if (a == 0)
break;
}
if (wp > hindex[i+1] ||
wp == hindex[i+1] && bp < U)
break;
v += a;
(void) printf("%.9lo\n", v);
}
}
return (0);
}