ChuanqiXu added a comment.

> I'm getting confused by the semantics of --p1689-targeted-output=. In D137527 
> <https://reviews.llvm.org/D137527>, it's used to populate 
> CompilerCommand::Output which is supposed to be the main compiler output (.o 
> file). Is that correct? If that's not the case and this flag is supposed to 
> only control where to put the JSON file with the dependency information, it 
> might as well have more generic name, like -o or --output and apply to the 
> rest of clang-scan-deps, no?

Correct. The semantics of `--p1689-targeted-output=` should be the same with 
the main compiler output (.o file).

> If we really want to avoid writing compilation databases, I think that 
> clang-scan-deps -format=p1689 -- <clang_flags> -std=c++20 <input> -o <output> 
> is much cleaner/generic/reusable than clang-scan-deps -format=p1689 
> --p1689-targeted-file-name=<input> --p1689-targeted-output=<output> -- 
> <clang_flags> -std=c++20. I understand that FixedCompilationDatabase 
> currently doesn't know what the input/output is unless you explicitly pass 
> that in. What if we were able to construct some kind of CompilationDatabase 
> by properly parsing the given complete command line into CompilerInvocation 
> and poking at FrontendOptions?

I was worrying about the complexity and I wanted to reuse 
FixedCompilationDatabase. I'd like to see if we can implement it simply.

> You still need to know where to put the P1689 
> <https://reviews.llvm.org/P1689> output and where the make-style dependency 
> info for files read during the scan need to go. I see these as distinctly 
> clang-scan-deps flags and should be *before* the --. Basically, it seems 
> weird to me to have the clang flags end up telling the scanner where to put 
> the -MF info (as it is now, but you want even fewer flags which I don't think 
> is workable as the information just isn't there).

Do you think it is OK to write: `clang-scan-deps -format=p1689 -- clang++ 
-std=c++20 -MD -MT <target_name> -MF <dep_file> -c input_file 
<any_other_needed_opts> -o output_file`?


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

https://reviews.llvm.org/D137534

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

Reply via email to