Quuxplusone added inline comments.

================
Comment at: clang/lib/Sema/SemaInit.cpp:4020
                                          bool IsListInit = false,
                                          bool IsInitListCopy = false) {
   assert(((!IsListInit && !IsInitListCopy) ||
----------------
Two comments you could act on if you want, or just ignore if they seem too 
scope-creepy:

(1) This function is //crazy// long and complicated. It would be great to break 
it down into named steps or subtasks.

(2) I'm still concerned about the repetition of `if (Result == OR_Deleted but 
Kind == IK_Copy) keep going`. IIUC, the intent is that this function should 
return the `InitializationSequence` that is found by overload resolution... but 
sometimes we can tell that overload resolution is going to find an 
inappropriate sequence (e.g. an explicit conversion, or a sequence that depends 
on a deleted function, or maybe some other situations) and in that case we want 
to short-circuit, because the caller is going to treat "No unique sequence" in 
the same way as "The unique sequence was inappropriate".  **Would it be better 
to** have the caller pass in a new function parameter, `bool 
ShortCircuitUnusableSequences`, which is usually `true` but can be explicitly 
set to `false` in the three cases (`return`, `co_return`, `throw`) where we 
currently want to treat "No unique sequence" differently from "The unique 
sequence was inappropriate"?

Then the repeated check would be `if (Result == OR_Deleted && 
ShortCircuitUnusableSequences) return;` and it would be a little clearer what's 
going on.

(Sidenote: Default function arguments, //especially// trailing boolean ones, 
[are the 
devil](https://quuxplusone.github.io/blog/2020/04/18/default-function-arguments-are-the-devil/#the-boolean-parameter-tarpit).)


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D92936

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

Reply via email to