erichkeane added inline comments.
================ Comment at: clang/lib/AST/Interp/ByteCodeExprGen.h:182-183 + template <typename VisitFn> + bool visitConditional(const AbstractConditionalOperator *E, VisitFn V); + ---------------- tbaeder wrote: > aaron.ballman wrote: > > The template definition isn't available within the header file, so this is > > fragile (impossible to instantiate from anything but ByteCodeExprGen.cpp). > What's the alternative? If I make it a static function in > `ByteCodeExprGen.cpp`, I'd have to make a lot of members of `ByteCodeEmitter` > etc. public which is not a very clean solution. Moving the definition into > the header file isn't very nice either, all the others are in the source file. What about making it a static template in `ByteCodeExprGen.cpp`, but make it a 'friend' here? I think that would work, wouldn't it? Something like: https://godbolt.org/z/ofYbGvfYa You unfortunately cannot make it static, but as it is a template, at least it is inline. WDYT? CHANGES SINCE LAST ACTION https://reviews.llvm.org/D141497/new/ https://reviews.llvm.org/D141497 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits