diff options
author | Chris Mihelich <cmihelic@google.com> | 2024-05-28 11:44:58 -0700 |
---|---|---|
committer | Copybara-Service <copybara-worker@google.com> | 2024-05-28 11:45:50 -0700 |
commit | 6ec17dc63626431c6d2b0403ad4c4b9ba1ceb7d3 (patch) | |
tree | f425d0fc6c441a0916d1d0234bf7fc429e1eba0e /absl/debugging/internal/demangle.cc | |
parent | 4a861bb14ba1baf203912f11360d4d8a6379faf7 (diff) | |
download | abseil-6ec17dc63626431c6d2b0403ad4c4b9ba1ceb7d3.tar.gz abseil-6ec17dc63626431c6d2b0403ad4c4b9ba1ceb7d3.tar.bz2 abseil-6ec17dc63626431c6d2b0403ad4c4b9ba1ceb7d3.zip |
Demangle &-qualified function types.
PiperOrigin-RevId: 637972935
Change-Id: Ia684f7761b2a98a0d9d5ae096daba34e9140aa22
Diffstat (limited to 'absl/debugging/internal/demangle.cc')
-rw-r--r-- | absl/debugging/internal/demangle.cc | 27 |
1 files changed, 19 insertions, 8 deletions
diff --git a/absl/debugging/internal/demangle.cc b/absl/debugging/internal/demangle.cc index 38b5458e..91bea72d 100644 --- a/absl/debugging/internal/demangle.cc +++ b/absl/debugging/internal/demangle.cc @@ -1386,19 +1386,30 @@ static bool ParseExceptionSpec(State *state) { return false; } -// <function-type> ::= [exception-spec] F [Y] <bare-function-type> [O] E +// <function-type> ::= +// [exception-spec] F [Y] <bare-function-type> [<ref-qualifier>] E +// +// <ref-qualifier> ::= R | O static bool ParseFunctionType(State *state) { ComplexityGuard guard(state); if (guard.IsTooComplex()) return false; ParseState copy = state->parse_state; - if (Optional(ParseExceptionSpec(state)) && ParseOneCharToken(state, 'F') && - Optional(ParseOneCharToken(state, 'Y')) && ParseBareFunctionType(state) && - Optional(ParseOneCharToken(state, 'O')) && - ParseOneCharToken(state, 'E')) { - return true; + Optional(ParseExceptionSpec(state)); + if (!ParseOneCharToken(state, 'F')) { + state->parse_state = copy; + return false; } - state->parse_state = copy; - return false; + Optional(ParseOneCharToken(state, 'Y')); + if (!ParseBareFunctionType(state)) { + state->parse_state = copy; + return false; + } + Optional(ParseCharClass(state, "RO")); + if (!ParseOneCharToken(state, 'E')) { + state->parse_state = copy; + return false; + } + return true; } // <bare-function-type> ::= <(signature) type>+ |