diff options
author | Chris Mihelich <cmihelic@google.com> | 2024-06-05 16:33:54 -0700 |
---|---|---|
committer | Copybara-Service <copybara-worker@google.com> | 2024-06-05 16:34:48 -0700 |
commit | 54e1f14c6f9b1a764ffdf8c1aea7e823f95f3d01 (patch) | |
tree | d7d22576bec1533a2592ebec7c0c96f57e957d53 /absl/debugging/internal/demangle.cc | |
parent | fe43a4cb564ef6dc731d52e8246c7ecbd1fd6bf5 (diff) | |
download | abseil-54e1f14c6f9b1a764ffdf8c1aea7e823f95f3d01.tar.gz abseil-54e1f14c6f9b1a764ffdf8c1aea7e823f95f3d01.tar.bz2 abseil-54e1f14c6f9b1a764ffdf8c1aea7e823f95f3d01.zip |
Demangle object new-expressions, [gs] nw ....
PiperOrigin-RevId: 640688552
Change-Id: I843e5aed55f90eeb89e007389390d0aba705a3fe
Diffstat (limited to 'absl/debugging/internal/demangle.cc')
-rw-r--r-- | absl/debugging/internal/demangle.cc | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/absl/debugging/internal/demangle.cc b/absl/debugging/internal/demangle.cc index 7fe8439b..761bde13 100644 --- a/absl/debugging/internal/demangle.cc +++ b/absl/debugging/internal/demangle.cc @@ -618,6 +618,7 @@ static bool ParseUnionSelector(State* state); static bool ParseFunctionParam(State* state); static bool ParseBracedExpression(State *state); static bool ParseExpression(State *state); +static bool ParseInitializer(State *state); static bool ParseExprPrimary(State *state); static bool ParseExprCastValueAndTrailingE(State *state); static bool ParseQRequiresClauseExpr(State *state); @@ -1993,6 +1994,8 @@ static bool ParseBracedExpression(State *state) { // ::= cv <type> _ <expression>* E # type (expr-list) // ::= tl <type> <braced-expression>* E // ::= il <braced-expression>* E +// ::= [gs] nw <expression>* _ <type> E +// ::= [gs] nw <expression>* _ <type> <initializer> // ::= dc <type> <expression> // ::= sc <type> <expression> // ::= cc <type> <expression> @@ -2088,6 +2091,17 @@ static bool ParseExpression(State *state) { } state->parse_state = copy; + // <expression> ::= [gs] nw <expression>* _ <type> E + // ::= [gs] nw <expression>* _ <type> <initializer> + if (Optional(ParseTwoCharToken(state, "gs")) && + ParseTwoCharToken(state, "nw") && + ZeroOrMore(ParseExpression, state) && ParseOneCharToken(state, '_') && + ParseType(state) && + (ParseOneCharToken(state, 'E') || ParseInitializer(state))) { + return true; + } + state->parse_state = copy; + // dynamic_cast, static_cast, const_cast, reinterpret_cast. // // <expression> ::= (dc | sc | cc | rc) <type> <expression> @@ -2272,6 +2286,20 @@ static bool ParseExpression(State *state) { return ParseUnresolvedName(state); } +// <initializer> ::= pi <expression>* E +static bool ParseInitializer(State *state) { + ComplexityGuard guard(state); + if (guard.IsTooComplex()) return false; + ParseState copy = state->parse_state; + + if (ParseTwoCharToken(state, "pi") && ZeroOrMore(ParseExpression, state) && + ParseOneCharToken(state, 'E')) { + return true; + } + state->parse_state = copy; + return false; +} + // <expr-primary> ::= L <type> <(value) number> E // ::= L <type> <(value) float> E // ::= L <mangled-name> E |