aganea marked 8 inline comments as done.
aganea added inline comments.

================
Comment at: clang/include/clang/Basic/CodeGenOptions.h:212
+  /// Output filename used in the COFF debug information.
+  std::string COFFOutputFilename;
+
----------------
rnk wrote:
> Let's bikeshed the name a bit. This thing is the `-o`/`/Fo` value, plus some 
> processing. It can be symbolic, as in `-`. It could be the name of a bitcode 
> file with `-flto`. It could be the name of an assembly file if you do `clang 
> -S --target=x86_64-windows-msvc -g t.cpp -o t.s`. It could be the name of an 
> ELF file if you try hard. I think in any of these cases where the user 
> directly emits something that isn't a COFF object, it's OK to use that name 
> for the S_OBJNAME record.
> 
> What it is, is the name of the compiler's output file, as we would like it to 
> appear in debug info. With that in mind, here are some ideas:
> - CodeViewObjectName: very directly referring to S_OBJNAME
> - ObjectFilename: very general
> - ObjectFilenameForDebug: generalizing over cv/dwarf
> - OutputFilenameForDebug: generalizing over assembly, bc, and obj
> 
> I think I like ObjectFilenameForDebug best. DebugObjectFilename seems like a 
> no-go, since that sounds like the dwo file name.
> 
> ---
> 
> This brings me to the case of `-save-temps` / `/Fa`. In these cases, the 
> compile action is broken into pieces, and the assembler is invoked in a 
> follow-up process. Does that mean the driver needs to pass an extra flag 
> along to the -cc1 action? That would be a bummer.
> 
I think we should fix `-save-temps` and `/Fa`, thanks for raising that! Would 
you mind if I added a new cc1 flag for that purpose? Something like 
`-target-file-name`.
When using `-save-temps`, each cc1 command doesn't know about the final 
filename, except for the last cc1 command. We would need to provide that name 
somehow when passing `-S`.


================
Comment at: llvm/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp:752
 
+static void unescapeSlashes(SmallVectorImpl<char> &Str) {
+  auto Read = Str.begin();
----------------
rnk wrote:
> This isn't unescaping them, it's just canonicalizing double slashes to one 
> slash, right? Would `llvm::sys::native` suffice?
`llvm::sys::path::native()` doesn't remove consecutive (back)slashes. I think 
@zturner's main intent was when debugging in Visual Studio with arguments from 
LIT tests, they sometimes contain double backslashes.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D43002

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
  • [PATCH] D43002: [CodeView]... Alexandre Ganea via Phabricator via cfe-commits

Reply via email to