source: trunk/indexers/mg/lib/huffman_stdio.c@ 7464

Last change on this file since 7464 was 3745, checked in by mdewsnip, 21 years ago

Addition of MG package for search and retrieval

  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 2.0 KB
Line 
1/**************************************************************************
2 *
3 * huffman_stdio.c -- Huffman coding function to a file
4 * Copyright (C) 1994 Neil Sharman
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 *
20 * $Id: huffman_stdio.c 3745 2003-02-20 21:20:24Z mdewsnip $
21 *
22 **************************************************************************/
23
24/*
25 $Log$
26 Revision 1.1 2003/02/20 21:14:16 mdewsnip
27 Addition of MG package for search and retrieval
28
29 Revision 1.1 1999/08/10 21:16:52 sjboddie
30 renamed mg-1.3d directory mg
31
32 Revision 1.1 1998/11/17 09:32:07 rjmcnab
33 *** empty log message ***
34
35 * Revision 1.1 1994/08/22 00:24:46 tes
36 * Initial placement under CVS.
37 *
38 */
39
40static char *RCSID = "$Id: huffman_stdio.c 3745 2003-02-20 21:20:24Z mdewsnip $";
41
42#include "sysfuncs.h"
43
44#include "bitio_m.h"
45#include "bitio_m_stdio.h"
46#include "huffman.h"
47
48#if 0
49int fprintf (FILE *, const char *,...);
50int _filbuf (FILE *);
51int _flsbuf (unsigned, FILE *);
52#endif
53
54void
55BIO_Stdio_Huff_Encode (unsigned long val, unsigned long *codes,
56 char *clens, stdio_bitio_state * bs)
57{
58 ENCODE_CONTINUE (*bs)
59 HUFF_ENCODE (val, codes, clens);
60 ENCODE_PAUSE (*bs)
61}
62
63unsigned long
64BIO_Stdio_Huff_Decode (unsigned long *mincodes,
65 unsigned long **values,
66 stdio_bitio_state * bs)
67{
68 unsigned long val;
69 DECODE_CONTINUE (*bs)
70 HUFF_DECODE (val, mincodes, values);
71 DECODE_PAUSE (*bs)
72 return (val);
73}
Note: See TracBrowser for help on using the repository browser.