+2012-01-16 Ulrich Drepper <drepper@gmail.com>
+
+ * stdlib/Makefile (tests): Add bug-fmtmsg1.
+ * stdlib/bug-fmtmsg1.c: New file.
+
+ * stdlib/fmtmsg.c (init): Add missing unlock.
+ Patch by Peng Haitao <penght@cn.fujitsu.com>.
+
2012-01-12 Marek Polacek <polacek@redhat.com>
* libio/bits/stdio2.h: Do not define gets for ISO C11, ISO C++11,
-# Copyright (C) 1991-2009, 2011 Free Software Foundation, Inc.
+# Copyright (C) 1991-2009, 2011, 2012 Free Software Foundation, Inc.
# This file is part of the GNU C Library.
# The GNU C Library is free software; you can redistribute it and/or
tst-atof1 tst-atof2 tst-strtod2 tst-strtod3 tst-rand48-2 \
tst-makecontext tst-strtod4 tst-strtod5 tst-qsort2 \
tst-makecontext2 tst-strtod6 tst-unsetenv1 \
- tst-makecontext3 bug-getcontext
+ tst-makecontext3 bug-getcontext bug-fmtmsg1
include ../Makeconfig
tst-strtod4-ENV = LOCPATH=$(common-objpfx)localedata
tst-strtod5-ENV = LOCPATH=$(common-objpfx)localedata
testmb2-ENV = LOCPATH=$(common-objpfx)localedata
+bug-fmtmsg1-ENV = SEV_LEVEL=foo,11,newsev
# Run a test on the header files we use.
tests: $(objpfx)isomac.out
--- /dev/null
+#include <fmtmsg.h>
+#include <stdio.h>
+
+
+static int
+do_test (void)
+{
+ /* Ugly, but fmtmsg would otherwise print to stderr which we do not
+ want. */
+ fclose (stderr);
+ stderr = stdout;
+
+ int e1;
+ e1 = fmtmsg (MM_PRINT, "label:part", MM_WARNING, "text", "action", "tag");
+
+ int e2;
+ e2 = fmtmsg (MM_PRINT, "label2:part2", 11, "text2", "action2", "tag2");
+
+ addseverity (10, "additional severity");
+
+ int e3;
+ e3 = fmtmsg (MM_PRINT, "label3:part3", 10, "text3", "action3", "tag3");
+
+ return e1 != 0 || e2 != 0 || e3 != 0;
+}
+
+#define TEST_FUNCTION do_test ()
+#include "../test-skeleton.c"
-/* Copyright (C) 1997,1999-2003,2005,2006,2011 Free Software Foundation, Inc.
+/* Copyright (C) 1997,1999-2003,2005,2006,2011,2012
+ Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
sevlevel_var = end + (*end == ':' ? 1 : 0);
}
+
+ __libc_lock_unlock (lock);
}
}