ENCODE(2) ENCODE(2) delim $$ NAME dec64, enc64, dec32, enc32, dec16, enc16, encodefmt - encoding byte arrays as strings SYNOPSIS #include <u.h> #include <libc.h> int dec64(uchar *out, int lim, char *in, int n) int enc64(char *out, int lim, uchar *in, int n) int dec32(uchar *out, int lim, char *in, int n) int enc32(char *out, int lim, uchar *in, int n) int dec16(uchar *out, int lim, char *in, int n) int enc16(char *out, int lim, uchar *in, int n) int encodefmt(Fmt*) DESCRIPTION Enc16, enc32 and enc64 create null terminated strings. They return the size of the encoded string (without the null) or -1 if the encoding fails. The encoding fails if lim, the length of the output buffer, is too small. They require $2n+1$, $(8n+4)/5+1$ and $(n+2)/3)*4 + 1$ bytes, respec- tively. Dec16, dec32 and dec64 return the number of bytes decoded or -1 if the decoding fails. The decoding fails if the output buffer is not large enough or, for base 32, if the input buffer length is not a multiple of 8. Encodefmt can be used with fmtinstall(2) and print(2) to print encoded representations of byte arrays. The verbs are H base 16 (i.e. hexadecimal). The default encoding is in upper case. The l flag forces lower case. < base 32 [ base 64 (same as MIME) The length of the array is specified as f2. For example, to display a 15 byte array as hex: char x[15]; Page 1 Plan 9 (printed 12/21/24) ENCODE(2) ENCODE(2) fmtinstall('H', encodefmt); print("%.*H\n", sizeof x, x); SOURCE /sys/src/libc/port/u16.c /sys/src/libc/port/u32.c /sys/src/libc/port/u64.c Page 2 Plan 9 (printed 12/21/24)