]> mj.ucw.cz Git - moe.git/blob - ucw/base224.h
MO-P: Public parts of /mo include templates
[moe.git] / ucw / base224.h
1 /*
2  *      UCW Library -- Base 224 Encoding & Decoding
3  *
4  *      (c) 2002 Martin Mares <mj@ucw.cz>
5  *
6  *      This software may be freely distributed and used according to the terms
7  *      of the GNU Lesser General Public License.
8  */
9
10 /**
11  * Encodes @len bytes of data pointed to by @src by base224 encoding.
12  * Stores them in @dest and returns the number of bytes the output
13  * takes.
14  */
15 uns base224_encode(byte *dest, const byte *src, uns len);
16 /**
17  * Decodes @len bytes of data pointed to by @src from base224 encoding.
18  * All invalid characters are ignored. The result is stored into @dest
19  * and length of the result is returned.
20  */
21 uns base224_decode(byte *dest, const byte *src, uns len);
22
23 /**
24  * Use this macro to calculate @base224_encode() output buffer size.
25  * It can happen 4 more bytes would be needed, this macro takes care
26  * of that.
27  */
28 #define BASE224_ENC_LENGTH(x) (((x)*8+38)/39*5)
29
30 /*
31  * When called for BASE224_IN_CHUNK-byte chunks, the result will be
32  * always BASE224_OUT_CHUNK bytes long. If a longer block is split
33  * to such chunks, the result will be identical.
34  */
35 #define BASE224_IN_CHUNK 39 /** Chunk size on the un-encoded side. **/
36 #define BASE224_OUT_CHUNK 40 /** Chunk size on the encoded side. **/