Resubmit r339450 - [MS Demangler] Add conversion operator tests
authorZachary Turner <zturner@google.com>
Fri, 10 Aug 2018 20:08:46 +0000 (20:08 +0000)
committerZachary Turner <zturner@google.com>
Fri, 10 Aug 2018 20:08:46 +0000 (20:08 +0000)
This was broken because of a malformed check line.  Incidentally,
this exposed a case where we crash when we should just be returning
an error, so we should fix that.  The demangler shouldn't crash due
to user input.

llvm-svn: 339466

llvm/test/Demangle/ms-conversion-operators.test

index afc34aab4fa7b61774ee496e6aecab92f84648e1..95cf1162f0033b4964d9ae3849225dba11bb7d91 100644 (file)
@@ -3,19 +3,49 @@
 ; CHECK-NOT: Invalid mangled name
 
 ??$?BH@TemplateOps@@QAEHXZ
+; CHECK: int __thiscall TemplateOps::operator<int> int(void)
+
 ??BOps@@QAEHXZ
+; CHECK: int __thiscall Ops::operator int(void)
+
 ??BConstOps@@QAE?BHXZ
+; CHECK: int const __thiscall ConstOps::operator int const(void)
+
 ??BVolatileOps@@QAE?CHXZ
+; CHECK: int volatile __thiscall VolatileOps::operator int volatile(void)
+
 ??BConstVolatileOps@@QAE?DHXZ
+; CHECK: int const volatile __thiscall ConstVolatileOps::operator int const volatile(void)
+
 ??$?BN@TemplateOps@@QAENXZ
+; CHECK: double __thiscall TemplateOps::operator<double> double(void)
+
 ??BOps@@QAENXZ
+; CHECK: double __thiscall Ops::operator double(void)
+
 ??BConstOps@@QAE?BNXZ
+; CHECK: double const __thiscall ConstOps::operator double const(void)
+
 ??BVolatileOps@@QAE?CNXZ
+; CHECK: double volatile __thiscall VolatileOps::operator double volatile(void)
+
 ??BConstVolatileOps@@QAE?DNXZ
+; CHECK: double const volatile __thiscall ConstVolatileOps::operator double const volatile(void)
+
 ??BCompoundTypeOps@@QAEPAHXZ
+; CHECK: nt * __thiscall CompoundTypeOps::operator int *(void)
+
 ??BCompoundTypeOps@@QAEPBHXZ
+; CHECK: int const * __thiscall CompoundTypeOps::operator int const *(void)
+
 ??BCompoundTypeOps@@QAE$$QAHXZ
+; CHECK: int && __thiscall CompoundTypeOps::operator int &&(void)
+
 ??BCompoundTypeOps@@QAE?AU?$Foo@H@@XZ
+; CHECK: struct Foo<int> __thiscall CompoundTypeOps::operator struct Foo<int>(void)
+
 ??$?BH@CompoundTypeOps@@QAE?AU?$Bar@U?$Foo@H@@@@XZ
-??$?BPAH@TemplateOps@@QAEPAHXZ
+; CHECK: struct Bar<struct Foo<int>> __thiscall CompoundTypeOps::operator<int> struct Bar<struct Foo<int>>(void)
 
+??$?BPAH@TemplateOps@@QAEPAHXZ
+; CHECK: int * __thiscall TemplateOps::operator<int *> int *(void)