From 2f61aed18c4affd3a75a2b2d2468d23f2f16192a Mon Sep 17 00:00:00 2001 From: Chris Mihelich Date: Fri, 7 Jun 2024 19:20:24 -0700 Subject: Demangle sr St , a dubious encoding found in the wild. PiperOrigin-RevId: 641418373 Change-Id: I2999228cccfd18a000725b938a692c0c9004867c --- absl/debugging/internal/demangle.cc | 13 +++++++++++++ 1 file changed, 13 insertions(+) (limited to 'absl/debugging/internal/demangle.cc') diff --git a/absl/debugging/internal/demangle.cc b/absl/debugging/internal/demangle.cc index d97dfad4..f9dff5d8 100644 --- a/absl/debugging/internal/demangle.cc +++ b/absl/debugging/internal/demangle.cc @@ -2034,6 +2034,13 @@ static bool ParseBaseUnresolvedName(State *state) { // // ::= [gs] sr + E // +// ::= sr St # nonstandard +// +// The last case is not part of the official grammar but has been observed in +// real-world examples that the GNU demangler (but not the LLVM demangler) is +// able to decode; see demangle_test.cc for one such symbol name. The shape +// sr St was inferred by closed-box testing of the GNU +// demangler. static bool ParseUnresolvedName(State *state) { ComplexityGuard guard(state); if (guard.IsTooComplex()) return false; @@ -2067,6 +2074,12 @@ static bool ParseUnresolvedName(State *state) { } state->parse_state = copy; + if (ParseTwoCharToken(state, "sr") && ParseTwoCharToken(state, "St") && + ParseSimpleId(state) && ParseSimpleId(state)) { + return true; + } + state->parse_state = copy; + return false; } -- cgit v1.2.3