From 3a1240afd3a04f697915652a0911e78995675b4c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tobias=20Nie=C3=9Fen?= Date: Sat, 4 Feb 2023 14:03:44 +0000 Subject: [PATCH] src: avoid leaking snapshot fp on error Call fclose() on the snapshot file regardless of whether reading the snapshot data succeeded. --- src/node.cc | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/node.cc b/src/node.cc index ed6b1c7a1a736d..c011f14ce3b600 100644 --- a/src/node.cc +++ b/src/node.cc @@ -1174,14 +1174,15 @@ ExitCode LoadSnapshotDataAndRun(const SnapshotData** snapshot_data_ptr, return exit_code; } std::unique_ptr read_data = std::make_unique(); - if (!SnapshotData::FromBlob(read_data.get(), fp)) { + bool ok = SnapshotData::FromBlob(read_data.get(), fp); + fclose(fp); + if (!ok) { // If we fail to read the customized snapshot, simply exit with 1. // TODO(joyeecheung): should be kStartupSnapshotFailure. exit_code = ExitCode::kGenericUserError; return exit_code; } *snapshot_data_ptr = read_data.release(); - fclose(fp); } else if (per_process::cli_options->node_snapshot) { // If --snapshot-blob is not specified, we are reading the embedded // snapshot, but we will skip it if --no-node-snapshot is specified.