akhuang added inline comments.

================
Comment at: clang/lib/Frontend/CompilerInstance.cpp:857-858
+      OS.reset(new llvm::raw_fd_ostream(Temp->FD, /*shouldClose=*/false,
+                                        Binary ? llvm::sys::fs::OF_None
+                                               : llvm::sys::fs::OF_Text));
+      OSFile = std::string(TempPath.str());
----------------
Quuxplusone wrote:
> amccarth wrote:
> > rnk wrote:
> > > I think the bug is here: the third parameter is `bool unbuffered`, not 
> > > file flags, so we are opening the file for unbuffered writing, and that 
> > > is really slow.
> > Yowza!  In addition to a fix, we need some memes.
> > 
> > * Why do we even have that lever?
> > * This constructor has too many overloads.  Please remove three.
> > * [Facepalm] `bool` parameters.  [Double facepalm]  Negative `bool` 
> > parameter names that default to `false`.
> > In addition to a fix, we need some memes.
> 
> https://quuxplusone.github.io/blog/2020/04/18/default-function-arguments-are-the-devil/
>  ;)
> I count 8 different signatures for `raw_fd_ostream`'s constructor, 3 of which 
> come from the offending default-argument'ed overload. And none of them are 
> `explicit`, which means e.g. `{42, false}` is a valid argument for a function 
> taking `const raw_fd_ostream&`.
> 
> Unrelated to argument lists, but I would add "using raw `new` instead of 
> `std::make_unique`" to this line's lengthy list of sins.
oh whoops, thanks for the catch - for now I guess I'll just remove the extra 
parameter


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D102736

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

Reply via email to