rnk added inline comments.

================
Comment at: clang/lib/AST/ASTContext.cpp:2490
+    ThisAdjustment += getASTRecordLayout(Derived).getBaseClassOffset(Base);
+    RD = Path[I];
+  }
----------------
rjmccall wrote:
> What should we do on targets that allow virtual bases in member pointer 
> conversions?
It looks like the MS ABI codepaths don't use this routine. If we could put it 
somewhere Itanium-specific that would be accessible to the mangler and CGCXXABI 
implementation, that would be ideal, but ASTContext doesn't seem too bad.


================
Comment at: clang/lib/AST/MicrosoftMangle.cpp:657-660
   // <member-function-pointer> ::= $1? <name>
   //                           ::= $H? <name> <number>
   //                           ::= $I? <name> <number> <number>
   //                           ::= $J? <name> <number> <number> <number>
----------------
rsmith wrote:
> For what it's worth, I'm fairly convinced the `$` is not actually part of the 
> mangling of the member function pointer, and is instead part of the mangling 
> of a non-type template argument (or more generally of a value).
That makes sense to me. I'll see if I can simplify in a follow-up.


================
Comment at: clang/lib/AST/MicrosoftMangle.cpp:751-752
+  // to convert every integer to signed 64 bit before mangling (including
+  // unsigned 64 bit values). Do the same, but preserve bits beyond the bottom
+  // 64.
+  llvm::APInt Value =
----------------
IIUC, this means we can mangle __int128 non-type template parms now? Let's add 
a test for that.


================
Comment at: clang/lib/AST/MicrosoftMangle.cpp:1746
+
+  case APValue::AddrLabelDiff:
+  case APValue::FixedPoint:
----------------
Why is this even an APValue kind... O_o


================
Comment at: clang/test/CodeGenCXX/mangle-class-nttp.cpp:27
+#ifndef _WIN32
+// FIXME: MSVC crashes on the first of these and mangles the second the same as
+// the nullptr version. Check the output is correct once we have a reference to
----------------
These FIXMEs represent a lot of future work. :(

Thanks for adding test coverage on both sides, though.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D89998/new/

https://reviews.llvm.org/D89998

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
  • [PATCH] D89998: [... Richard Smith - zygoloid via Phabricator via cfe-commits
    • [PATCH] D899... John McCall via Phabricator via cfe-commits
    • [PATCH] D899... Reid Kleckner via Phabricator via cfe-commits
    • [PATCH] D899... Richard Smith - zygoloid via Phabricator via cfe-commits
    • [PATCH] D899... Richard Smith - zygoloid via Phabricator via cfe-commits
    • [PATCH] D899... Richard Smith - zygoloid via Phabricator via cfe-commits
    • [PATCH] D899... Richard Smith - zygoloid via Phabricator via cfe-commits
    • [PATCH] D899... John McCall via Phabricator via cfe-commits
    • [PATCH] D899... Richard Smith - zygoloid via Phabricator via cfe-commits

Reply via email to