Commit 4cc48683 by Tom Tromey Committed by Tom Tromey

cplus-dem.c (consume_count): If `count' wraps, return 0 and don't advance input pointer.

	* cplus-dem.c (consume_count): If `count' wraps, return 0 and
	don't advance input pointer.
	(demangle_class_name): If consume_count didn't find a count, do
	nothing.  Don't bother with `strlen' sanity check; consume_count
	does it for us.

From-SVN: r26068
parent 85a0b075
1999-03-30 Tom Tromey <tromey@cygnus.com>
* cplus-dem.c (consume_count): If `count' wraps, return 0 and
don't advance input pointer.
(demangle_class_name): If consume_count didn't find a count, do
nothing. Don't bother with `strlen' sanity check; consume_count
does it for us.
Thu Mar 11 01:22:58 1999 Mumit Khan <khan@xraylith.wisc.edu>
* pexecute.c (__CYGWIN32__): Rename to
......
......@@ -428,12 +428,22 @@ static int
consume_count (type)
const char **type;
{
int count = 0;
unsigned int count = 0;
char *save = *type;
while (isdigit ((unsigned char)**type))
{
count *= 10;
count += **type - '0';
/* A sanity check. Otherwise a symbol like
`_Utf390_1__1_9223372036854775807__9223372036854775'
can cause this function to return a negative value.
In this case we just consume until the end of the string. */
if (count > strlen (*type))
{
*type = save;
return 0;
}
(*type)++;
}
return (count);
......@@ -1946,7 +1956,7 @@ demangle_class_name (work, mangled, declp)
int success = 0;
n = consume_count (mangled);
if ((int) strlen (*mangled) >= n)
if (n > 0)
{
demangle_arm_hp_template (work, mangled, n, declp);
success = 1;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment