aaron.ballman added inline comments.
================ Comment at: clang/lib/AST/Interp/ByteCodeExprGen.cpp:642 + + for (const auto *Init : Ctor->inits()) { + const FieldDecl *Member = Init->getMember(); ---------------- Do we have to do anything special if the ctor is an inheriting ctor? ================ Comment at: clang/lib/AST/Interp/ByteCodeExprGen.cpp:687 + return true; + } else if (const CallExpr *CE = dyn_cast<CallExpr>(Initializer)) { + const Decl *Callee = CE->getCalleeDecl(); ---------------- `CXXMemberCallExpr` as well? ================ Comment at: clang/lib/AST/Interp/ByteCodeExprGen.cpp:689 + const Decl *Callee = CE->getCalleeDecl(); + const Function *Func = P.getFunction(dyn_cast<FunctionDecl>(Callee)); + ---------------- What if this comes back as `nullptr` (does `getFunction()` handle that gracefully)? ================ Comment at: clang/lib/AST/Interp/ByteCodeExprGen.cpp:316 + // Base above gives us a pointer on the stack. + const auto *FD = dyn_cast<FieldDecl>(Member); + assert(FD); ---------------- shafik wrote: > tbaeder wrote: > > erichkeane wrote: > > > I THINK Member is a ValueDecl because it could be a member function, > > > right? So forcing it to be a FieldDecl here is likely not valid. > > > Perhaps in the 'non-FieldDecl' case we could jsut return false for now? > > > > > > ALSO, don't do a dyn_cast followed by an assert, `cast` will do the > > > assert for you. > > Right, I was just trying to limit the code to the subset I've implemented > > for now. I can try to make it more defensive. > Also I believe this can also be an `IndirectFieldDecl` (anonymous union > members) or a `ValueDecl` for static data members. > > Maybe outline what is left to fill in a comment? There are quite a few kinds of declarations, but many of them don't matter or only matter in special circumstances. Like `StaticAssertDecl` shouldn't be something we can visit here, but technically `TypedefDecl` can because of VLA evaluations. `MSPropertyDecl` is one that could possibly matter as well. CHANGES SINCE LAST ACTION https://reviews.llvm.org/D134057/new/ https://reviews.llvm.org/D134057 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits