From 3c7d100ab1ff7805444f6f64cb2339ccb4546e16 Mon Sep 17 00:00:00 2001 From: Ajeet D'Souza <98ajeet@gmail.com> Date: Mon, 30 Mar 2020 03:04:39 +0530 Subject: [PATCH] Guarantee unique file names for temporary database --- src/db.rs | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/db.rs b/src/db.rs index 2af013c..e8f9e7e 100644 --- a/src/db.rs +++ b/src/db.rs @@ -6,7 +6,7 @@ use serde::{Deserialize, Serialize}; use uuid::Uuid; use std::cmp::Ordering; -use std::fs::{self, File}; +use std::fs::{self, File, OpenOptions}; use std::io::{self, BufRead, BufReader, BufWriter}; use std::path::{Path, PathBuf}; @@ -77,8 +77,12 @@ impl DB { if self.modified { let path_tmp = self.get_path_tmp(); - let file_tmp = - File::create(&path_tmp).context("could not open temporary database file")?; + let file_tmp = OpenOptions::new() + .write(true) + // ensure that we are not overwriting an existing file_tmp + .create_new(true) + .open(&path_tmp) + .context("could not open temporary database file")?; let writer = BufWriter::new(&file_tmp); bincode::serialize_into(writer, &self.data).context("could not serialize database")?;