erichkeane added a comment.

I'm still having trouble from the description and test figuring out what this 
means.  Can you better clarify the intent/effect of this?

Is the point that the type-aliases could also store a non-canonicalized type?  
if so, perhaps the patch should better reflect that (AND, perhaps do some 
assertions to make sure we don't unintentionally store types that don't 
canonicalize identically).



================
Comment at: clang/include/clang/AST/Type.h:1802
+    /// True if the underlying diverges from the declared one.
+    unsigned isDivergent : 1;
+  };
----------------
It isn't clear to me what you mean by 'diverges' and 'divergent here.


================
Comment at: clang/lib/AST/Type.cpp:3443
+  if (isDivergent())
+    *reinterpret_cast<QualType *>(this + 1) = Underlying;
 }
----------------
this bit doesn't seem right to me.  Why isn't this using the normal setter 
here?  Or even the trailing objects setter?


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D133468

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to