kadircet added inline comments.

================
Comment at: lib/Sema/SemaCodeComplete.cpp:1639
+        llvm::raw_string_ostream OS(OverrideSignature);
+        CodeCompletionResult CCR(Method, 0);
+        PrintingPolicy Policy =
----------------
ioeric wrote:
> kadircet wrote:
> > ioeric wrote:
> > > Could you add comments explaining what the following code does? The 
> > > original code in clangd only has `Results.emplace_back(Method, 0);`, and 
> > > it's non-trivial what the new code here is for.
> > Yeah you are right added some comments, previously this was handled on 
> > CodeCompletionBuilder in clangd which converted the completion item into a 
> > override declaration to be inserted.
> Thanks! Could you elaborate on why you need to explicitly handle `CCR` and 
> `CCS`, i.e. why was `Results.emplace_back(Method, 0);` not enough? I guess 
> it's to avoid inserting return type when it's already typed, but it's not 
> obvious from the code.
Actually it is to generate a new CodeCompletionString with a single TypedText 
chunk that will include all of the declaration. Since you need to type whole 
declaration, which is also the part that has been used to filter completion 
candidates based on completion token.

It also helped me notice a bug relating optional params, I wasn't putting them 
into the typedtext chunk whereas I should've, fixed that one also.


Repository:
  rC Clang

https://reviews.llvm.org/D52225



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

Reply via email to