table of contents
scan_cescape(3) | Library Functions Manual | scan_cescape(3) |
NAME¶
scan_cescape - parse C escaped string
SYNTAX¶
#include <libowfat/textcode.h>
size_t scan_cescape(const char *src,char *dest,size_t* destlen);
DESCRIPTION¶
scan_cescape parses C escaped text from src into dest. Parsing stops at the 0 terminator, invalid input characters or a double quote that was not escaped.
C escape sequences like \n and \x0a and \012 are translated into their binary counterparts. The C99 escape sequences \u and \U are supported and lead to UTF-8 sequences being output.
scan_cescape will then write the number of bytes in dest into *destlen, and return the number of bytes decoded from src.
dest can be NULL. destlen can be NULL. dest can be src.
To make sure dest is large enough, either allocate strlen(src)+1 bytes or call scan_cescape twice, the first time with dest == NULL (*destlen will still be written).
RETURN VALUE¶
scan_cescape returns the number of bytes successfully parsed from src.
EXAMPLES¶
scan_cescape("test\n
SEE ALSO¶
fmt_jsonescape(3), fmt_cescape(3), scan_ldapescape(3)