]> granicus.if.org Git - llvm/commitdiff
[demangler] Ignore leading underscores if present
authorErik Pilkington <erik.pilkington@gmail.com>
Thu, 17 Jan 2019 21:37:36 +0000 (21:37 +0000)
committerErik Pilkington <erik.pilkington@gmail.com>
Thu, 17 Jan 2019 21:37:36 +0000 (21:37 +0000)
On MacOS, symbols start with a leading underscore, so just parse and
ignore it if present.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@351481 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Demangle/ItaniumDemangle.h

index 53107c9c8d99028d1452bbe36d278cbcaf5b96ee..9a54ff5d80d59505f072df5e9deee4954bdb2dca 100644 (file)
@@ -5143,7 +5143,7 @@ AbstractManglingParser<Derived, Alloc>::parseTemplateArgs(bool TagTemplates) {
 // extension      ::= ___Z <encoding> _block_invoke_<decimal-digit>+
 template <typename Derived, typename Alloc>
 Node *AbstractManglingParser<Derived, Alloc>::parse() {
-  if (consumeIf("_Z")) {
+  if (consumeIf("_Z") || consumeIf("__Z")) {
     Node *Encoding = getDerived().parseEncoding();
     if (Encoding == nullptr)
       return nullptr;
@@ -5156,7 +5156,7 @@ Node *AbstractManglingParser<Derived, Alloc>::parse() {
     return Encoding;
   }
 
-  if (consumeIf("___Z")) {
+  if (consumeIf("___Z") || consumeIf("____Z")) {
     Node *Encoding = getDerived().parseEncoding();
     if (Encoding == nullptr || !consumeIf("_block_invoke"))
       return nullptr;