mirror of
https://sourceware.org/git/glibc.git
synced 2025-08-07 06:43:00 +03:00
Update.
1999-08-23 Ulrich Drepper <drepper@cygnus.com> * posix/regexbug1.c: Make it an error if the test fails. 1999-08-23 Andreas Schwab <schwab@suse.de> Ulrich Drepper <drepper@cygnus.com> * posix/regex.c (re_match_2_internal): Correct check for charset after exactn in loop.
This commit is contained in:
10
ChangeLog
10
ChangeLog
@@ -1,3 +1,13 @@
|
||||
1999-08-23 Ulrich Drepper <drepper@cygnus.com>
|
||||
|
||||
* posix/regexbug1.c: Make it an error if the test fails.
|
||||
|
||||
1999-08-23 Andreas Schwab <schwab@suse.de>
|
||||
Ulrich Drepper <drepper@cygnus.com>
|
||||
|
||||
* posix/regex.c (re_match_2_internal): Correct check for charset
|
||||
after exactn in loop.
|
||||
|
||||
1999-08-22 Ulrich Drepper <drepper@cygnus.com>
|
||||
|
||||
* sysdeps/unix/sysv/linux/powerpc/syscalls.list: Add execve syscall.
|
||||
|
@@ -4833,26 +4833,23 @@ re_match_2_internal (bufp, string1, size1, string2, size2, pos, regs, stop)
|
||||
}
|
||||
else if ((re_opcode_t) *p2 == charset)
|
||||
{
|
||||
#ifdef DEBUG
|
||||
register unsigned char c
|
||||
= *p2 == (unsigned char) endline ? '\n' : p2[2];
|
||||
#endif
|
||||
if ((re_opcode_t) p1[3] == exactn)
|
||||
{
|
||||
unsigned char *p1end = &p1[5] + p1[4];
|
||||
unsigned char *runp1 = &p1[5];
|
||||
|
||||
#if 0
|
||||
if ((re_opcode_t) p1[3] == exactn
|
||||
&& ! ((int) p2[1] * BYTEWIDTH > (int) p1[5]
|
||||
&& (p2[2 + p1[5] / BYTEWIDTH]
|
||||
& (1 << (p1[5] % BYTEWIDTH)))))
|
||||
#else
|
||||
if ((re_opcode_t) p1[3] == exactn
|
||||
&& ! ((int) p2[1] * BYTEWIDTH > (int) p1[4]
|
||||
&& (p2[2 + p1[4] / BYTEWIDTH]
|
||||
& (1 << (p1[4] % BYTEWIDTH)))))
|
||||
#endif
|
||||
{
|
||||
p[-3] = (unsigned char) pop_failure_jump;
|
||||
DEBUG_PRINT3 (" %c != %c => pop_failure_jump.\n",
|
||||
c, p1[5]);
|
||||
while (runp1 < p1end)
|
||||
{
|
||||
if ((int) p2[1] * BYTEWIDTH <= (int) *runp1
|
||||
|| (p2[2 + *runp1 / BYTEWIDTH]
|
||||
& (1 << (*runp1 % BYTEWIDTH))) == 0)
|
||||
{
|
||||
p[-3] = (unsigned char) pop_failure_jump;
|
||||
DEBUG_PRINT1 (" No match => pop_failure_jump.\n");
|
||||
break;
|
||||
}
|
||||
++runp1;
|
||||
}
|
||||
}
|
||||
|
||||
else if ((re_opcode_t) p1[3] == charset_not)
|
||||
|
@@ -23,9 +23,8 @@ main (void)
|
||||
if (regexec (&re, "002", 2, ma, 0) != 0)
|
||||
{
|
||||
error (0, 0, "\"0*[0-9][0-9]\" did not match \"002\"");
|
||||
/* Comment the following line out until the bug is fixed. */
|
||||
//res = 1;
|
||||
res = 1;
|
||||
}
|
||||
|
||||
return 0;
|
||||
return res;
|
||||
}
|
||||
|
Reference in New Issue
Block a user