* cplus-dem.c (cplus_demangle): Fix formatting.
(grow_vect): Ditto. (ada_demangle): Ditto. (internal_cplus_demangle): Ditto. (mop_up): Ditto. * cplus-dem.c (main): Handle java_demangling. * cplus-dem.c (grow_vect): Prototype. (ada_demangle): Cast the arg of ctype macros to unsigned char.
This commit is contained in:
parent
d57fc35284
commit
f17755262c
|
@ -1,3 +1,20 @@
|
|||
2000-11-21 Hans-Peter Nilsson <hp@bitrange.com>
|
||||
|
||||
* cplus-dem.c (cplus_demangle): Fix formatting.
|
||||
(grow_vect): Ditto.
|
||||
(ada_demangle): Ditto.
|
||||
(internal_cplus_demangle): Ditto.
|
||||
(mop_up): Ditto.
|
||||
|
||||
2000-11-21 H.J. Lu <hjl@gnu.org>
|
||||
|
||||
* cplus-dem.c (main): Handle java_demangling.
|
||||
|
||||
2000-11-21 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
|
||||
|
||||
* cplus-dem.c (grow_vect): Prototype.
|
||||
(ada_demangle): Cast the arg of ctype macros to unsigned char.
|
||||
|
||||
2000-11-15 Hans-Peter Nilsson <hp@bitrange.com>
|
||||
|
||||
* cplus-dem.c (ada_demangle): Add back ATTRIBUTE_UNUSED for
|
||||
|
|
|
@ -527,6 +527,9 @@ static void
|
|||
recursively_demangle PARAMS ((struct work_stuff *, const char **, string *,
|
||||
int));
|
||||
|
||||
static void
|
||||
grow_vect PARAMS ((void **, size_t *, size_t, int));
|
||||
|
||||
/* Translate count to integer, consuming tokens in the process.
|
||||
Conversion terminates on the first non-digit character.
|
||||
|
||||
|
@ -926,6 +929,7 @@ cplus_demangle (mangled, options)
|
|||
/* Assuming *OLD_VECT points to an array of *SIZE objects of size
|
||||
ELEMENT_SIZE, grow it to contain at least MIN_SIZE objects,
|
||||
updating *OLD_VECT and *SIZE as necessary. */
|
||||
|
||||
static void
|
||||
grow_vect (old_vect, size, min_size, element_size)
|
||||
void **old_vect;
|
||||
|
@ -933,7 +937,8 @@ grow_vect (old_vect, size, min_size, element_size)
|
|||
size_t min_size;
|
||||
int element_size;
|
||||
{
|
||||
if (*size < min_size) {
|
||||
if (*size < min_size)
|
||||
{
|
||||
*size *= 2;
|
||||
if (*size < min_size)
|
||||
*size = min_size;
|
||||
|
@ -945,11 +950,10 @@ grow_vect (old_vect, size, min_size, element_size)
|
|||
1. Discard final __{DIGIT}+ or ${DIGIT}+
|
||||
2. Convert other instances of embedded "__" to `.'.
|
||||
3. Discard leading _ada_.
|
||||
4. Remove everything after first ___ if it is followed by
|
||||
'X'.
|
||||
4. Remove everything after first ___ if it is followed by 'X'.
|
||||
5. Put symbols that should be suppressed in <...> brackets.
|
||||
The resulting string is valid until the next call of ada_demangle.
|
||||
*/
|
||||
The resulting string is valid until the next call of ada_demangle. */
|
||||
|
||||
static char *
|
||||
ada_demangle (mangled, option)
|
||||
const char *mangled;
|
||||
|
@ -995,8 +999,8 @@ ada_demangle (mangled, option)
|
|||
sizeof (char));
|
||||
demangled = demangling_buffer;
|
||||
|
||||
if (isdigit (mangled[len0 - 1])) {
|
||||
for (i = len0-2; i >= 0 && isdigit (mangled[i]); i -= 1)
|
||||
if (isdigit ((unsigned char) mangled[len0 - 1])) {
|
||||
for (i = len0 - 2; i >= 0 && isdigit ((unsigned char) mangled[i]); i -= 1)
|
||||
;
|
||||
if (i > 1 && mangled[i] == '_' && mangled[i - 1] == '_')
|
||||
{
|
||||
|
@ -1010,7 +1014,8 @@ ada_demangle (mangled, option)
|
|||
}
|
||||
}
|
||||
|
||||
for (i = 0, j = 0; i < len0 && ! isalpha (mangled[i]); i += 1, j += 1)
|
||||
for (i = 0, j = 0; i < len0 && ! isalpha ((unsigned char)mangled[i]);
|
||||
i += 1, j += 1)
|
||||
demangled[j] = mangled[i];
|
||||
|
||||
at_start_name = 1;
|
||||
|
@ -1033,7 +1038,7 @@ ada_demangle (mangled, option)
|
|||
demangled[j] = '\000';
|
||||
|
||||
for (i = 0; demangled[i] != '\0'; i += 1)
|
||||
if (isupper (demangled[i]) || demangled[i] == ' ')
|
||||
if (isupper ((unsigned char)demangled[i]) || demangled[i] == ' ')
|
||||
goto Suppress;
|
||||
|
||||
if (! changed)
|
||||
|
@ -1122,7 +1127,7 @@ internal_cplus_demangle (work, mangled)
|
|||
work->destructor = s2;
|
||||
work->static_type = s3;
|
||||
work->type_quals = s4;
|
||||
return (demangled);
|
||||
return demangled;
|
||||
}
|
||||
|
||||
|
||||
|
@ -5092,6 +5097,7 @@ main (argc, argv)
|
|||
case gnu_demangling:
|
||||
case lucid_demangling:
|
||||
case arm_demangling:
|
||||
case java_demangling:
|
||||
case edg_demangling:
|
||||
valid_symbols = standard_symbol_characters ();
|
||||
break;
|
||||
|
|
Loading…
Reference in New Issue