X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/11e2fb2dbbc074cce78d62fdf425e6bbf1918949..fe36a7ee2f4304fd3797443d4f2f950d6dc2475d:/h/fmt_scan.h?ds=inline diff --git a/h/fmt_scan.h b/h/fmt_scan.h index e35bfa20..5f659d4c 100644 --- a/h/fmt_scan.h +++ b/h/fmt_scan.h @@ -114,6 +114,12 @@ struct fmt_callbacks { char *new_fs (char *form, char *format, char *default_fs); +/* + * Free memory allocated by new_fs(). It allocates to a static so + * no argument is necessary. + */ +void free_fs (); + /* * Compile a format string into a set of format instructions. Arguments are: * @@ -138,11 +144,11 @@ int fmt_compile (char *fstring, struct format **fmt, int reset); * Interpret a sequence of compiled format instructions. Arguments are: * * format - Array of format instructions generated by fmt_compile() - * scanl - Passed-in character array that will contain the output - * of the format instructions. Is always terminated with - * a newline (\n). - * max - Maximum number of bytes to be written to "scanl" (in other - * words, the buffer size). Includes the trailing NUL. + * scanl - Passed-in charstring_t object (created with + * charstring_create() and later destroyed with + * charstring_free()) that will contain the output of the + * format instructions. Is always terminated with a + * newline (\n). * width - Maximum number of displayed characters. Does not include * characters marked as nonprinting or (depending on the * encoding) bytes in a multibyte encoding that exceed the @@ -169,8 +175,8 @@ int fmt_compile (char *fstring, struct format **fmt, int reset); * execute, which is currently always NULL. */ -struct format *fmt_scan (struct format *format, char *scanl, size_t max, - int width, int *dat, struct fmt_callbacks *callbacks); +struct format *fmt_scan (struct format *format, charstring_t scanl, int width, + int *dat, struct fmt_callbacks *callbacks); /* * Free a format structure and/or component hash table. Arguments are: