Guarantee unique file names for temporary database

This commit is contained in:
Ajeet D'Souza 2020-03-30 03:04:39 +05:30
parent 78a3d0a3d9
commit 3c7d100ab1

View File

@ -6,7 +6,7 @@ use serde::{Deserialize, Serialize};
use uuid::Uuid; use uuid::Uuid;
use std::cmp::Ordering; use std::cmp::Ordering;
use std::fs::{self, File}; use std::fs::{self, File, OpenOptions};
use std::io::{self, BufRead, BufReader, BufWriter}; use std::io::{self, BufRead, BufReader, BufWriter};
use std::path::{Path, PathBuf}; use std::path::{Path, PathBuf};
@ -77,8 +77,12 @@ impl DB {
if self.modified { if self.modified {
let path_tmp = self.get_path_tmp(); let path_tmp = self.get_path_tmp();
let file_tmp = let file_tmp = OpenOptions::new()
File::create(&path_tmp).context("could not open temporary database file")?; .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); let writer = BufWriter::new(&file_tmp);
bincode::serialize_into(writer, &self.data).context("could not serialize database")?; bincode::serialize_into(writer, &self.data).context("could not serialize database")?;