diff options
| author | Rich Felker <dalias@aerifal.cx> | 2012-03-25 00:21:20 -0400 | 
|---|---|---|
| committer | Rich Felker <dalias@aerifal.cx> | 2012-03-25 00:21:20 -0400 | 
| commit | bff650df9f1f6a0da80d8894535a41b0a2cca320 (patch) | |
| tree | ada4f3bb329c20582a895774feaa54919293e7c1 | |
| parent | df82f8f2dcbf35ba0e91b8d529491178d896b3b5 (diff) | |
| download | musl-bff650df9f1f6a0da80d8894535a41b0a2cca320.tar.gz | |
add strfmon_l variant (still mostly incomplete)
| -rw-r--r-- | src/locale/strfmon.c | 30 | 
1 files changed, 27 insertions, 3 deletions
| diff --git a/src/locale/strfmon.c b/src/locale/strfmon.c index 66bee482..81dfe38f 100644 --- a/src/locale/strfmon.c +++ b/src/locale/strfmon.c @@ -3,16 +3,15 @@  #include <stdarg.h>  #include <monetary.h>  #include <errno.h> +#include <stdarg.h> -ssize_t strfmon(char *s, size_t n, const char *fmt, ...) +static ssize_t vstrfmon_l(char *s, size_t n, locale_t loc, const char *fmt, va_list ap)  {  	size_t l;  	double x;  	int fill, nogrp, negpar, nosym, left, intl;  	int lp, rp, w, fw;  	char *s0=s; -	va_list ap; -	va_start(ap, fmt);  	for (; n && *fmt; ) {  		if (*fmt != '%') {  		literal: @@ -75,3 +74,28 @@ ssize_t strfmon(char *s, size_t n, const char *fmt, ...)  	}  	return s-s0;  } + +ssize_t strfmon_l(char *s, size_t n, locale_t loc, const char *fmt, ...) +{ +	va_list ap; +	ssize_t ret; + +	va_start(ap, fmt); +	ret = vstrfmon_l(s, n, loc, fmt, ap); +	va_end(ap); + +	return ret; +} + + +ssize_t strfmon(char *s, size_t n, const char *fmt, ...) +{ +	va_list ap; +	ssize_t ret; + +	va_start(ap, fmt); +	ret = vstrfmon_l(s, n, 0, fmt, ap); +	va_end(ap); + +	return ret; +} | 
