|
Packit |
6c4009 |
#include <assert.h>
|
|
Packit |
6c4009 |
#include <mcheck.h>
|
|
Packit |
6c4009 |
#include <nl_types.h>
|
|
Packit |
6c4009 |
#include <stdio.h>
|
|
Packit |
6c4009 |
#include <stdlib.h>
|
|
Packit |
6c4009 |
#include <string.h>
|
|
Packit |
6c4009 |
#include <sys/resource.h>
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
static const char *msgs[] =
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
#define INPUT(str)
|
|
Packit |
6c4009 |
#define OUTPUT(str) str,
|
|
Packit |
6c4009 |
#include <intl/msgs.h>
|
|
Packit |
6c4009 |
};
|
|
Packit |
6c4009 |
#define nmsgs (sizeof (msgs) / sizeof (msgs[0]))
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
/* Test for unbounded alloca. */
|
|
Packit |
6c4009 |
static int
|
|
Packit |
6c4009 |
do_bz17905 (void)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
char *buf;
|
|
Packit |
6c4009 |
struct rlimit rl;
|
|
Packit |
6c4009 |
nl_catd result __attribute__ ((unused));
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
const int sz = 1024 * 1024;
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
getrlimit (RLIMIT_STACK, &rl);
|
|
Packit |
6c4009 |
rl.rlim_cur = sz;
|
|
Packit |
6c4009 |
setrlimit (RLIMIT_STACK, &rl);
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
buf = malloc (sz + 1);
|
|
Packit |
6c4009 |
memset (buf, 'A', sz);
|
|
Packit |
6c4009 |
buf[sz] = '\0';
|
|
Packit |
6c4009 |
setenv ("NLSPATH", buf, 1);
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
result = catopen (buf, NL_CAT_LOCALE);
|
|
Packit |
6c4009 |
assert (result == (nl_catd) -1);
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
free (buf);
|
|
Packit |
6c4009 |
return 0;
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
#define ROUNDS 5
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
static int
|
|
Packit |
6c4009 |
do_test (void)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
int rnd;
|
|
Packit |
6c4009 |
int result = 0;
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
mtrace ();
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
/* We do this a few times to stress the memory handling. */
|
|
Packit |
6c4009 |
for (rnd = 0; rnd < ROUNDS; ++rnd)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
nl_catd cd = catopen ("libc", 0);
|
|
Packit |
6c4009 |
size_t cnt;
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
if (cd == (nl_catd) -1)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
printf ("cannot load catalog: %m\n");
|
|
Packit |
6c4009 |
result = 1;
|
|
Packit |
6c4009 |
break;
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
/* Go through all the messages and compare the result. */
|
|
Packit |
6c4009 |
for (cnt = 0; cnt < nmsgs; ++cnt)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
char *trans;
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
trans = catgets (cd, 1, 1 + cnt,
|
|
Packit |
6c4009 |
"+#+# if this comes backs it's an error");
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
if (trans == NULL)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
printf ("catgets return NULL for %zd\n", cnt);
|
|
Packit |
6c4009 |
result = 1;
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
else if (strcmp (trans, msgs[cnt]) != 0 && msgs[cnt][0] != '\0')
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
printf ("expected \"%s\", got \"%s\"\n", msgs[cnt], trans);
|
|
Packit |
6c4009 |
result = 1;
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
if (catclose (cd) != 0)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
printf ("catclose failed: %m\n");
|
|
Packit |
6c4009 |
result = 1;
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
result += do_bz17905 ();
|
|
Packit |
6c4009 |
return result;
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
#define TEST_FUNCTION do_test ()
|
|
Packit |
6c4009 |
#include "../test-skeleton.c"
|