Update.
authorUlrich Drepper <drepper@redhat.com>
Sat, 29 Jan 2000 08:35:47 +0000 (08:35 +0000)
committerUlrich Drepper <drepper@redhat.com>
Sat, 29 Jan 2000 08:35:47 +0000 (08:35 +0000)
* locale/programs/ld-numeric.c (numeric_output): Increment cnt in
correct place to avoid uninitialized memory passed to writev.

ChangeLog
locale/programs/ld-numeric.c

index 712002e..4d88955 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
 2000-01-29  Ulrich Drepper  <drepper@redhat.com>
 
+       * locale/programs/ld-numeric.c (numeric_output): Increment cnt in
+       correct place to avoid uninitialized memory passed to writev.
+
        * locale/programs/ld-monetary.c (STR_ELEM_WC): Fix test for too
        long string in definition.Only enable returning wide character
        strings if really needed.
index 37951c8..017c41f 100644 (file)
@@ -104,15 +104,6 @@ numeric_finish (struct localedef_t *locale, struct charmap_t *charmap)
        }
     }
 
-#define TEST_ELEM(cat, default)                                                      \
-  if (numeric->cat == NULL && ! be_quiet && ! nothing)                       \
-    error (0, 0, _("%s: field `%s' not defined"), "LC_NUMERIC", #cat);       \
-  if (numeric->cat##_wc == L'\0')                                            \
-    numeric->cat##_wc = default
-
-  TEST_ELEM (decimal_point, L'.');
-  TEST_ELEM (thousands_sep, L'\0');
-
   /* The decimal point must not be empty.  This is not said explicitly
      in POSIX but ANSI C (ISO/IEC 9899) says in 4.4.2.1 it has to be
      != "".  */
@@ -129,6 +120,8 @@ numeric_finish (struct localedef_t *locale, struct charmap_t *charmap)
 %s: value for field `%s' must not be the empty string"),
             "LC_NUMERIC", "decimal_point");
     }
+  if (numeric->decimal_point_wc == L'\0')
+    numeric->decimal_point_wc = L'.';
 
   if (numeric->grouping_len == 0 && ! be_quiet && ! nothing)
     error (0, 0, _("%s: field `%s' not defined"), "LC_NUMERIC", "grouping");
@@ -168,6 +161,7 @@ numeric_output (struct localedef_t *locale, struct charmap_t *charmap,
   idx[cnt - 2] = idx[cnt - 3] + iov[cnt - 1].iov_len;
   iov[cnt].iov_base = numeric->grouping;
   iov[cnt].iov_len = numeric->grouping_len;
+  ++cnt;
 
   idx[cnt - 2] = iov[0].iov_len + iov[1].iov_len;
   iov[cnt].iov_base = (void *) &numeric->decimal_point_wc;
@@ -176,8 +170,7 @@ numeric_output (struct localedef_t *locale, struct charmap_t *charmap,
 
   idx[cnt - 2] = idx[cnt - 3] + iov[cnt - 1].iov_len;
   iov[cnt].iov_base = (void *) &numeric->thousands_sep_wc;
-  iov[cnt].iov_len = sizeof (uint32_t);;
-  ++cnt;
+  iov[cnt].iov_len = sizeof (uint32_t);
 
   assert (cnt + 1 == 2 + _NL_ITEM_INDEX (_NL_NUM_LC_NUMERIC));