mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-12-14 03:29:57 +00:00
Add an -fno-temp-file flag for compilation
Our build system does not handle randomly named files created during the build well. We'd prefer to write compilation output directly without creating a temporary file. Function parameters already existed to control this behavior but were not exposed all the way out to the command line. Patch by Zachary Henkel! Differential revision: https://reviews.llvm.org/D70615
This commit is contained in:
parent
5e5e99c041
commit
d129aa1d53
@ -1563,6 +1563,9 @@ def fno_strict_enums : Flag<["-"], "fno-strict-enums">, Group<f_Group>;
|
||||
def fno_strict_vtable_pointers: Flag<["-"], "fno-strict-vtable-pointers">,
|
||||
Group<f_Group>;
|
||||
def fno_strict_overflow : Flag<["-"], "fno-strict-overflow">, Group<f_Group>;
|
||||
def fno_temp_file : Flag<["-"], "fno-temp-file">, Group<f_Group>,
|
||||
Flags<[CC1Option, CoreOption]>, HelpText<
|
||||
"Directly create compilation output files. This may lead to incorrect incremental builds if the compiler crashes">;
|
||||
def fno_threadsafe_statics : Flag<["-"], "fno-threadsafe-statics">, Group<f_Group>,
|
||||
Flags<[CC1Option]>, HelpText<"Do not emit code to make initialization of local statics thread safe">;
|
||||
def fno_use_cxa_atexit : Flag<["-"], "fno-use-cxa-atexit">, Group<f_Group>, Flags<[CC1Option]>,
|
||||
|
@ -294,6 +294,9 @@ public:
|
||||
/// Whether timestamps should be written to the produced PCH file.
|
||||
unsigned IncludeTimestamps : 1;
|
||||
|
||||
/// Should a temporary file be used during compilation.
|
||||
unsigned UseTemporary : 1;
|
||||
|
||||
CodeCompleteOptions CodeCompleteOpts;
|
||||
|
||||
/// Specifies the output format of the AST.
|
||||
|
@ -5029,6 +5029,7 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
|
||||
Args.AddLastArg(CmdArgs, options::OPT_ftime_trace_granularity_EQ);
|
||||
Args.AddLastArg(CmdArgs, options::OPT_ftrapv);
|
||||
Args.AddLastArg(CmdArgs, options::OPT_malign_double);
|
||||
Args.AddLastArg(CmdArgs, options::OPT_fno_temp_file);
|
||||
|
||||
if (Arg *A = Args.getLastArg(options::OPT_ftrapv_handler_EQ)) {
|
||||
CmdArgs.push_back("-ftrapv-handler");
|
||||
|
@ -672,7 +672,7 @@ CompilerInstance::createDefaultOutputFile(bool Binary, StringRef InFile,
|
||||
StringRef Extension) {
|
||||
return createOutputFile(getFrontendOpts().OutputFile, Binary,
|
||||
/*RemoveFileOnSignal=*/true, InFile, Extension,
|
||||
/*UseTemporary=*/true);
|
||||
getFrontendOpts().UseTemporary);
|
||||
}
|
||||
|
||||
std::unique_ptr<raw_pwrite_stream> CompilerInstance::createNullOutputFile() {
|
||||
|
@ -1887,6 +1887,7 @@ static InputKind ParseFrontendArgs(FrontendOptions &Opts, ArgList &Args,
|
||||
Opts.ModulesEmbedFiles = Args.getAllArgValues(OPT_fmodules_embed_file_EQ);
|
||||
Opts.ModulesEmbedAllFiles = Args.hasArg(OPT_fmodules_embed_all_files);
|
||||
Opts.IncludeTimestamps = !Args.hasArg(OPT_fno_pch_timestamp);
|
||||
Opts.UseTemporary = !Args.hasArg(OPT_fno_temp_file);
|
||||
|
||||
Opts.CodeCompleteOpts.IncludeMacros
|
||||
= Args.hasArg(OPT_code_completion_macros);
|
||||
|
@ -140,7 +140,7 @@ GeneratePCHAction::CreateOutputFile(CompilerInstance &CI, StringRef InFile,
|
||||
std::unique_ptr<raw_pwrite_stream> OS =
|
||||
CI.createOutputFile(CI.getFrontendOpts().OutputFile, /*Binary=*/true,
|
||||
/*RemoveFileOnSignal=*/false, InFile,
|
||||
/*Extension=*/"", /*UseTemporary=*/true);
|
||||
/*Extension=*/"", CI.getFrontendOpts().UseTemporary);
|
||||
if (!OS)
|
||||
return nullptr;
|
||||
|
||||
|
@ -588,3 +588,6 @@
|
||||
// CHECK-TRIVIAL-PATTERN-NOT: hasn't been enabled
|
||||
// CHECK-TRIVIAL-ZERO-GOOD-NOT: hasn't been enabled
|
||||
// CHECK-TRIVIAL-ZERO-BAD: hasn't been enabled
|
||||
|
||||
// RUN: %clang -### -S -fno-temp-file %s 2>&1 | FileCheck -check-prefix=CHECK-NO-TEMP-FILE %s
|
||||
// CHECK-NO-TEMP-FILE: "-fno-temp-file"
|
Loading…
Reference in New Issue
Block a user