mirror of
https://sourceware.org/git/glibc.git
synced 2025-11-28 23:44:09 +03:00
Update.
* posix/fnmatch_loop.c: Fix computation of alignment. 2001-08-09 Isamu Hasegawa <isamu@yamato.ibm.com> * posix/regex.c (wcs_regex_compile): Use appropriate string to compare with collating element. Fix the padding for the alignment. 2001-08-09 Isamu Hasegawa <isamu@yamato.ibm.com> * locale/programs/ld-collate.c (collate_output): Exclude characters from elem_table. Reduce if clause to write collating elements correctly. * posix/Makefile (tests): Add bug-regex5. * posix/bug-regex5.c: New file. 2001-08-09 Ulrich Drepper <drepper@redhat.com>
This commit is contained in:
18
ChangeLog
18
ChangeLog
@@ -1,3 +1,21 @@
|
|||||||
|
2001-08-09 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
|
* posix/fnmatch_loop.c: Fix computation of alignment.
|
||||||
|
|
||||||
|
2001-08-09 Isamu Hasegawa <isamu@yamato.ibm.com>
|
||||||
|
|
||||||
|
* posix/regex.c (wcs_regex_compile): Use appropriate string
|
||||||
|
to compare with collating element.
|
||||||
|
Fix the padding for the alignment.
|
||||||
|
|
||||||
|
2001-08-09 Isamu Hasegawa <isamu@yamato.ibm.com>
|
||||||
|
|
||||||
|
* locale/programs/ld-collate.c (collate_output): Exclude
|
||||||
|
characters from elem_table.
|
||||||
|
Reduce if clause to write collating elements correctly.
|
||||||
|
* posix/Makefile (tests): Add bug-regex5.
|
||||||
|
* posix/bug-regex5.c: New file.
|
||||||
|
|
||||||
2001-08-09 Ulrich Drepper <drepper@redhat.com>
|
2001-08-09 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
* locale/lc-time.c (_nl_parse_alt_digit): New function.
|
* locale/lc-time.c (_nl_parse_alt_digit): New function.
|
||||||
|
|||||||
@@ -2449,7 +2449,7 @@ collate_output (struct localedef_t *locale, struct charmap_t *charmap,
|
|||||||
runp = collate->start;
|
runp = collate->start;
|
||||||
while (runp != NULL)
|
while (runp != NULL)
|
||||||
{
|
{
|
||||||
if (runp->mbs != NULL && runp->weights != NULL)
|
if (runp->mbs != NULL && runp->weights != NULL && !runp->is_character)
|
||||||
{
|
{
|
||||||
/* Compute the hash value of the name. */
|
/* Compute the hash value of the name. */
|
||||||
uint32_t namelen = strlen (runp->name);
|
uint32_t namelen = strlen (runp->name);
|
||||||
@@ -2469,7 +2469,7 @@ collate_output (struct localedef_t *locale, struct charmap_t *charmap,
|
|||||||
idx -= elem_size;
|
idx -= elem_size;
|
||||||
}
|
}
|
||||||
while (elem_table[idx * 2] != 0);
|
while (elem_table[idx * 2] != 0);
|
||||||
|
}
|
||||||
/* This is the spot where we will insert the value. */
|
/* This is the spot where we will insert the value. */
|
||||||
elem_table[idx * 2] = hash;
|
elem_table[idx * 2] = hash;
|
||||||
elem_table[idx * 2 + 1] = obstack_object_size (&extrapool);
|
elem_table[idx * 2 + 1] = obstack_object_size (&extrapool);
|
||||||
@@ -2500,7 +2500,6 @@ collate_output (struct localedef_t *locale, struct charmap_t *charmap,
|
|||||||
|
|
||||||
obstack_int32_grow (&extrapool, runp->wcseqorder);
|
obstack_int32_grow (&extrapool, runp->wcseqorder);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
runp = runp->next;
|
runp = runp->next;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -70,7 +70,7 @@ tests := tstgetopt testfnm runtests runptests \
|
|||||||
tst-getlogin tst-mmap tst-getaddrinfo tst-truncate \
|
tst-getlogin tst-mmap tst-getaddrinfo tst-truncate \
|
||||||
tst-truncate64 tst-fork tst-fnmatch tst-regexloc tst-dir \
|
tst-truncate64 tst-fork tst-fnmatch tst-regexloc tst-dir \
|
||||||
tst-chmod bug-regex1 bug-regex2 bug-regex3 bug-regex4 \
|
tst-chmod bug-regex1 bug-regex2 bug-regex3 bug-regex4 \
|
||||||
tst-gnuglob tst-regex
|
tst-gnuglob tst-regex bug-regex5
|
||||||
ifeq (yes,$(build-shared))
|
ifeq (yes,$(build-shared))
|
||||||
test-srcs := globtest
|
test-srcs := globtest
|
||||||
tests += wordexp-test tst-exec tst-spawn
|
tests += wordexp-test tst-exec tst-spawn
|
||||||
@@ -123,6 +123,7 @@ tst-fnmatch-ENV = LOCPATH=$(common-objpfx)localedata
|
|||||||
tst-regexloc-ENV = LOCPATH=$(common-objpfx)localedata
|
tst-regexloc-ENV = LOCPATH=$(common-objpfx)localedata
|
||||||
bug-regex1-ENV = LOCPATH=$(common-objpfx)localedata
|
bug-regex1-ENV = LOCPATH=$(common-objpfx)localedata
|
||||||
tst-regex-ENV = LOCPATH=$(common-objpfx)localedata
|
tst-regex-ENV = LOCPATH=$(common-objpfx)localedata
|
||||||
|
bug-regex5-ENV = LOCPATH=$(common-objpfx)localedata
|
||||||
|
|
||||||
testcases.h: TESTS TESTS2C.sed
|
testcases.h: TESTS TESTS2C.sed
|
||||||
sed -f TESTS2C.sed < $< > $@T
|
sed -f TESTS2C.sed < $< > $@T
|
||||||
|
|||||||
61
posix/bug-regex5.c
Normal file
61
posix/bug-regex5.c
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <locale.h>
|
||||||
|
#include <locale/localeinfo.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
main (void)
|
||||||
|
{
|
||||||
|
int32_t table_size, idx, i, found;
|
||||||
|
const int32_t *symb_table;
|
||||||
|
const unsigned char *extra;
|
||||||
|
uint32_t nrules;
|
||||||
|
char *ca;
|
||||||
|
|
||||||
|
ca = setlocale (LC_ALL, "da_DK.ISO-8859-1");
|
||||||
|
if (ca == NULL)
|
||||||
|
{
|
||||||
|
printf ("cannot set locale: %m\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
printf ("current locale : %s\n", ca);
|
||||||
|
|
||||||
|
nrules = _NL_CURRENT_WORD (LC_COLLATE, _NL_COLLATE_NRULES);
|
||||||
|
if (nrules == 0)
|
||||||
|
{
|
||||||
|
printf("No rule\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
table_size = _NL_CURRENT_WORD (LC_COLLATE, _NL_COLLATE_SYMB_HASH_SIZEMB);
|
||||||
|
symb_table = (const int32_t *)
|
||||||
|
_NL_CURRENT (LC_COLLATE, _NL_COLLATE_SYMB_TABLEMB);
|
||||||
|
extra = (const unsigned char *)
|
||||||
|
_NL_CURRENT (LC_COLLATE, _NL_COLLATE_SYMB_EXTRAMB);
|
||||||
|
|
||||||
|
found = 0;
|
||||||
|
for (i = 0; i < table_size; ++i)
|
||||||
|
{
|
||||||
|
if (symb_table[2 * i] != 0)
|
||||||
|
{
|
||||||
|
char elem[256];
|
||||||
|
idx = symb_table[2 * i + 1];
|
||||||
|
strncpy (elem, extra + idx + 1, extra[idx]);
|
||||||
|
elem[extra[idx]] = '\0';
|
||||||
|
printf ("Found a collating element: %s\n", elem);
|
||||||
|
++found;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (found == 0)
|
||||||
|
{
|
||||||
|
printf ("No collating element!\n");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
else if (found != 4)
|
||||||
|
{
|
||||||
|
printf ("expected 4 collating elements, found %d\n", found);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
@@ -531,7 +531,7 @@ FCT (pattern, string, string_end, no_leading_period, flags)
|
|||||||
|
|
||||||
idx += 1 + extra[idx];
|
idx += 1 + extra[idx];
|
||||||
/* Adjust for the alignment. */
|
/* Adjust for the alignment. */
|
||||||
idx = (idx + 3) & ~4;
|
idx = (idx + 3) & ~3;
|
||||||
|
|
||||||
wextra = (int32_t *) &extra[idx + 4];
|
wextra = (int32_t *) &extra[idx + 4];
|
||||||
# endif
|
# endif
|
||||||
|
|||||||
@@ -3055,7 +3055,7 @@ PREFIX(regex_compile) (ARG_PREFIX(pattern), ARG_PREFIX(size), syntax, bufp)
|
|||||||
/* First compare the hashing value. */
|
/* First compare the hashing value. */
|
||||||
if (symb_table[2 * elem] == hash
|
if (symb_table[2 * elem] == hash
|
||||||
&& c1 == extra[symb_table[2 * elem + 1]]
|
&& c1 == extra[symb_table[2 * elem + 1]]
|
||||||
&& memcmp (str,
|
&& memcmp (char_str,
|
||||||
&extra[symb_table[2 * elem + 1]
|
&extra[symb_table[2 * elem + 1]
|
||||||
+ 1], c1) == 0)
|
+ 1], c1) == 0)
|
||||||
{
|
{
|
||||||
@@ -3075,7 +3075,7 @@ PREFIX(regex_compile) (ARG_PREFIX(pattern), ARG_PREFIX(size), syntax, bufp)
|
|||||||
in the table. */
|
in the table. */
|
||||||
idx += 1 + extra[idx];
|
idx += 1 + extra[idx];
|
||||||
/* Adjust for the alignment. */
|
/* Adjust for the alignment. */
|
||||||
idx = (idx + 3) & ~4;
|
idx = (idx + 3) & ~3;
|
||||||
|
|
||||||
str[0] = (wchar_t) idx + 4;
|
str[0] = (wchar_t) idx + 4;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user