aboutsummaryrefslogtreecommitdiff
path: root/src/Compilation.zig
diff options
context:
space:
mode:
Diffstat (limited to 'src/Compilation.zig')
-rw-r--r--src/Compilation.zig13
1 files changed, 8 insertions, 5 deletions
diff --git a/src/Compilation.zig b/src/Compilation.zig
index 0ff9481875..659cfda9bd 100644
--- a/src/Compilation.zig
+++ b/src/Compilation.zig
@@ -1109,11 +1109,6 @@ pub fn create(gpa: Allocator, options: InitOptions) !*Compilation {
const use_stage1 = options.use_stage1 orelse false;
- const cache_mode = if (use_stage1 and !options.disable_lld_caching)
- CacheMode.whole
- else
- options.cache_mode;
-
// Make a decision on whether to use LLVM or our own backend.
const use_llvm = build_options.have_llvm and blk: {
if (options.use_llvm) |explicit|
@@ -1154,6 +1149,14 @@ pub fn create(gpa: Allocator, options: InitOptions) !*Compilation {
}
}
+ // TODO: once we support incremental compilation for the LLVM backend via
+ // saving the LLVM module into a bitcode file and restoring it, along with
+ // compiler state, the second clause here can be removed so that incremental
+ // cache mode is used for LLVM backend too. We need some fuzz testing before
+ // that can be enabled.
+ const cache_mode = if ((use_stage1 and !options.disable_lld_caching) or
+ (use_llvm and !options.disable_lld_caching)) CacheMode.whole else options.cache_mode;
+
const tsan = options.want_tsan orelse false;
// TSAN is implemented in C++ so it requires linking libc++.
const link_libcpp = options.link_libcpp or tsan;