aboutsummaryrefslogtreecommitdiff
path: root/src/locale
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2012-03-25 00:21:20 -0400
committerRich Felker <dalias@aerifal.cx>2012-03-25 00:21:20 -0400
commitbff650df9f1f6a0da80d8894535a41b0a2cca320 (patch)
treeada4f3bb329c20582a895774feaa54919293e7c1 /src/locale
parentdf82f8f2dcbf35ba0e91b8d529491178d896b3b5 (diff)
downloadmusl-bff650df9f1f6a0da80d8894535a41b0a2cca320.zip
musl-bff650df9f1f6a0da80d8894535a41b0a2cca320.tar.gz
musl-bff650df9f1f6a0da80d8894535a41b0a2cca320.tar.bz2
add strfmon_l variant (still mostly incomplete)
Diffstat (limited to 'src/locale')
-rw-r--r--src/locale/strfmon.c30
1 files changed, 27 insertions, 3 deletions
diff --git a/src/locale/strfmon.c b/src/locale/strfmon.c
index 66bee48..81dfe38 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;
+}