aganea added inline comments.

================
Comment at: clang/include/clang/Frontend/CompilerInstance.h:170
     std::string TempFilename;
+    Optional<llvm::sys::fs::TempFile> TempFile;
 
----------------
Can we always use `TempFile`? And remove `TempFilename` in that case?


================
Comment at: clang/lib/Frontend/CompilerInstance.cpp:728
+
+    std::string ErrorMsg;
+    if (OF.TempFile) {
----------------
I think the idea overall in LLVM is to defer the error rendering as late as 
possible. You could probably only keep an `Error` variable here, and render it 
below in the diagnostic with `toString(E)`.


================
Comment at: clang/lib/Frontend/CompilerInstance.cpp:733
+    } else {
+      if (std::error_code EC =
+              llvm::sys::fs::rename(OF.TempFilename, NewOutFile))
----------------
Here you can probably use `ECError` or `errorCodeToError()` with what is said 
slightly above.


================
Comment at: clang/lib/Frontend/CompilerInstance.cpp:840
     int fd;
-    std::error_code EC = llvm::sys::fs::createUniqueFile(
-        TempPath, fd, TempPath,
-        Binary ? llvm::sys::fs::OF_None : llvm::sys::fs::OF_Text);
+#if _WIN32
+    // On Windows, use llvm::sys::fs::TempFile to write the output file so
----------------
Usually it is better to avoid platform-specific logic. Could we use `TempFile` 
all the time on all platforms?


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