diff --git a/src/node_sea.cc b/src/node_sea.cc index bef7fe7c22739c..1cb09365dfca54 100644 --- a/src/node_sea.cc +++ b/src/node_sea.cc @@ -373,7 +373,14 @@ std::optional ParseSingleExecutableConfig( return std::nullopt; } if (use_code_cache.value()) { - result.flags |= SeaFlags::kUseCodeCache; + if (use_snapshot.value()) { + // TODO(joyeecheung): code cache in snapshot should be configured by + // separate snapshot configurations. + FPrintF(stderr, + "\"useCodeCache\" is redundant when \"useSnapshot\" is true\n"); + } else { + result.flags |= SeaFlags::kUseCodeCache; + } } auto assets_opt = parser.GetTopLevelStringDict("assets"); @@ -529,19 +536,14 @@ ExitCode GenerateSingleExecutableBlob( std::optional optional_sv_code_cache; std::string code_cache; if (static_cast(config.flags & SeaFlags::kUseCodeCache)) { - if (builds_snapshot_from_main) { - FPrintF(stderr, - "\"useCodeCache\" is redundant when \"useSnapshot\" is true\n"); - } else { - std::optional optional_code_cache = - GenerateCodeCache(config.main_path, main_script); - if (!optional_code_cache.has_value()) { - FPrintF(stderr, "Cannot generate V8 code cache\n"); - return ExitCode::kGenericUserError; - } - code_cache = optional_code_cache.value(); - optional_sv_code_cache = code_cache; + std::optional optional_code_cache = + GenerateCodeCache(config.main_path, main_script); + if (!optional_code_cache.has_value()) { + FPrintF(stderr, "Cannot generate V8 code cache\n"); + return ExitCode::kGenericUserError; } + code_cache = optional_code_cache.value(); + optional_sv_code_cache = code_cache; } std::unordered_map assets;