Skip to content

Commit

Permalink
Merge branch 'main' into feature/async_incompatible
Browse files Browse the repository at this point in the history
  • Loading branch information
simonsan authored Nov 18, 2024
2 parents c968a76 + 27bbbbd commit c5ecc23
Show file tree
Hide file tree
Showing 16 changed files with 182 additions and 80 deletions.
56 changes: 25 additions & 31 deletions crates/backend/src/local.rs
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,25 @@ impl LocalBackend {
})
}

/// Base path of the given file type and id.
///
/// # Arguments
///
/// * `tpe` - The type of the file.
/// * `id` - The id of the file.
///
/// # Returns
///
/// The base path of the file.
fn base_path(&self, tpe: FileType, id: &Id) -> PathBuf {
let hex_id = id.to_hex();
match tpe {
FileType::Config => self.path.clone(),
FileType::Pack => self.path.join("data").join(&hex_id[0..2]),
_ => self.path.join(tpe.dirname()),
}
}

/// Path to the given file type and id.
///
/// If the file type is `FileType::Pack`, the id will be used to determine the subdirectory.
Expand All @@ -86,8 +105,7 @@ impl LocalBackend {
let hex_id = id.to_hex();
match tpe {
FileType::Config => self.path.join("config"),
FileType::Pack => self.path.join("data").join(&hex_id[0..2]).join(hex_id),
_ => self.path.join(tpe.dirname()).join(hex_id),
_ => self.base_path(tpe, id).join(hex_id),
}
}

Expand Down Expand Up @@ -169,21 +187,6 @@ impl LocalBackend {
}
Ok(())
}

/// Returns the parent path of the given file type and id.
///
/// # Arguments
///
/// * `tpe` - The type of the file.
/// * `id` - The id of the file.
///
/// # Returns
///
/// The parent path of the file or `None` if the file does not have a parent.
fn parent_path(&self, tpe: FileType, id: &Id) -> Option<PathBuf> {
let path = self.path(tpe, id);
path.parent().map(Path::to_path_buf)
}
}

impl ReadBackend for LocalBackend {
Expand Down Expand Up @@ -312,7 +315,7 @@ impl ReadBackend for LocalBackend {
})
.inspect(|r| {
if let Err(err) = r {
error!("Error while listing files: {err:?}");
error!("Error while listing files: {}", err.display_log());
}
})
.filter_map(RusticResult::ok);
Expand Down Expand Up @@ -496,19 +499,10 @@ impl WriteBackend for LocalBackend {
trace!("writing tpe: {:?}, id: {}", &tpe, &id);
let filename = self.path(tpe, id);

let Some(parent) = self.parent_path(tpe, id) else {
return Err(
RusticError::new(
ErrorKind::Backend,
"The file `{path}` does not have a parent directory. This may be empty or a root path. Please check the file and try again.",
)
.attach_context("path", filename.display().to_string())
.ask_report()
);
};
let parent = self.base_path(tpe, id);

// create parent directory if it does not exist
fs::create_dir_all(parent.clone()).map_err(|err| {
fs::create_dir_all(&parent).map_err(|err| {
RusticError::with_source(
ErrorKind::InputOutput,
"Failed to create directories `{path}`. Does the directory already exist? Please check the file and try again.",
Expand Down Expand Up @@ -570,7 +564,7 @@ impl WriteBackend for LocalBackend {

if let Some(command) = &self.post_create_command {
if let Err(err) = Self::call_command(tpe, id, &filename, command) {
warn!("post-create: {err}");
warn!("post-create: {}", err.display_log());
}
}
Ok(())
Expand Down Expand Up @@ -600,7 +594,7 @@ impl WriteBackend for LocalBackend {
)?;
if let Some(command) = &self.post_delete_command {
if let Err(err) = Self::call_command(tpe, id, &filename, command) {
warn!("post-delete: {err}");
warn!("post-delete: {}", err.display_log());
}
}
Ok(())
Expand Down
2 changes: 1 addition & 1 deletion crates/backend/src/opendal.rs
Original file line number Diff line number Diff line change
Expand Up @@ -328,7 +328,7 @@ impl ReadBackend for OpenDALBackend {
})
.inspect(|r| {
if let Err(err) = r {
error!("Error while listing files: {err:?}");
error!("Error while listing files: {}", err.display_log());
}
})
.filter_map(RusticResult::ok)
Expand Down
8 changes: 4 additions & 4 deletions crates/core/src/archiver.rs
Original file line number Diff line number Diff line change
Expand Up @@ -144,15 +144,15 @@ impl<'a, BE: DecryptFullBackend, I: ReadGlobalIndex> Archiver<'a, BE, I> {
match src.size() {
Ok(Some(size)) => p.set_length(size),
Ok(None) => {}
Err(err) => warn!("error determining backup size: {err}"),
Err(err) => warn!("error determining backup size: {}", err.display_log()),
}
}
});

// filter out errors and handle as_path
let iter = src.entries().filter_map(|item| match item {
Err(e) => {
warn!("ignoring error {e}\n");
Err(err) => {
warn!("ignoring error: {}", err.display_log());
None
}
Ok(ReadSourceEntry { path, node, open }) => {
Expand Down Expand Up @@ -197,7 +197,7 @@ impl<'a, BE: DecryptFullBackend, I: ReadGlobalIndex> Archiver<'a, BE, I> {
.filter_map(|item| match item {
Ok(item) => Some(item),
Err(err) => {
warn!("ignoring error: {err:?}");
warn!("ignoring error: {}", err.display_log());
None
}
})
Expand Down
15 changes: 11 additions & 4 deletions crates/core/src/archiver/parent.rs
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,10 @@ impl Parent {
let tree = tree_id.and_then(|tree_id| match Tree::from_backend(be, index, tree_id) {
Ok(tree) => Some(tree),
Err(err) => {
warn!("ignoring error when loading parent tree {tree_id}: {err}");
warn!(
"ignoring error when loading parent tree {tree_id}: {}",
err.display_log()
);
None
}
});
Expand Down Expand Up @@ -202,7 +205,10 @@ impl Parent {
|tree_id| match Tree::from_backend(be, index, tree_id) {
Ok(tree) => Some(tree),
Err(err) => {
warn!("ignoring error when loading parent tree {tree_id}: {err}");
warn!(
"ignoring error when loading parent tree {tree_id}: {}",
err.display_log()
);
None
}
},
Expand Down Expand Up @@ -274,8 +280,9 @@ impl Parent {
ParentResult::Matched(())
} else {
warn!(
"missing blobs in index for unchanged file {path:?}; re-reading file",
);
"missing blobs in index for unchanged file {}; re-reading file",
path.display()
);
ParentResult::NotFound
}
}
Expand Down
35 changes: 28 additions & 7 deletions crates/core/src/backend/cache.rs
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,10 @@ impl ReadBackend for CachedBackend {

if tpe.is_cacheable() {
if let Err(err) = self.cache.remove_not_in_list(tpe, &list) {
warn!("Error in cache backend removing files {tpe:?}: {err}");
warn!(
"Error in cache backend removing files {tpe:?}: {}",
err.display_log()
);
}
}

Expand All @@ -95,12 +98,18 @@ impl ReadBackend for CachedBackend {
match self.cache.read_full(tpe, id) {
Ok(Some(data)) => return Ok(data),
Ok(None) => {}
Err(err) => warn!("Error in cache backend reading {tpe:?},{id}: {err}"),
Err(err) => warn!(
"Error in cache backend reading {tpe:?},{id}: {}",
err.display_log()
),
}
let res = self.be.read_full(tpe, id);
if let Ok(data) = &res {
if let Err(err) = self.cache.write_bytes(tpe, id, data) {
warn!("Error in cache backend writing {tpe:?},{id}: {err}");
warn!(
"Error in cache backend writing {tpe:?},{id}: {}",
err.display_log()
);
}
}
res
Expand Down Expand Up @@ -138,14 +147,20 @@ impl ReadBackend for CachedBackend {
match self.cache.read_partial(tpe, id, offset, length) {
Ok(Some(data)) => return Ok(data),
Ok(None) => {}
Err(err) => warn!("Error in cache backend reading {tpe:?},{id}: {err}"),
Err(err) => warn!(
"Error in cache backend reading {tpe:?},{id}: {}",
err.display_log()
),
};
// read full file, save to cache and return partial content
match self.be.read_full(tpe, id) {
Ok(data) => {
let range = offset as usize..(offset + length) as usize;
if let Err(err) = self.cache.write_bytes(tpe, id, &data) {
warn!("Error in cache backend writing {tpe:?},{id}: {err}");
warn!(
"Error in cache backend writing {tpe:?},{id}: {}",
err.display_log()
);
}
Ok(Bytes::copy_from_slice(&data.slice(range)))
}
Expand Down Expand Up @@ -187,7 +202,10 @@ impl WriteBackend for CachedBackend {
fn write_bytes(&self, tpe: FileType, id: &Id, cacheable: bool, buf: Bytes) -> RusticResult<()> {
if cacheable || tpe.is_cacheable() {
if let Err(err) = self.cache.write_bytes(tpe, id, &buf) {
warn!("Error in cache backend writing {tpe:?},{id}: {err}");
warn!(
"Error in cache backend writing {tpe:?},{id}: {}",
err.display_log()
);
}
}
self.be.write_bytes(tpe, id, cacheable, buf)
Expand All @@ -204,7 +222,10 @@ impl WriteBackend for CachedBackend {
fn remove(&self, tpe: FileType, id: &Id, cacheable: bool) -> RusticResult<()> {
if cacheable || tpe.is_cacheable() {
if let Err(err) = self.cache.remove(tpe, id) {
warn!("Error in cache backend removing {tpe:?},{id}: {err}");
warn!(
"Error in cache backend removing {tpe:?},{id}: {}",
err.display_log()
);
}
}
self.be.remove(tpe, id, cacheable)
Expand Down
8 changes: 4 additions & 4 deletions crates/core/src/backend/ignore.rs
Original file line number Diff line number Diff line change
Expand Up @@ -358,10 +358,10 @@ impl ReadSource for LocalSource {
fn size(&self) -> RusticResult<Option<u64>> {
let mut size = 0;
for entry in self.builder.build() {
if let Err(e) = entry.and_then(|e| e.metadata()).map(|m| {
if let Err(err) = entry.and_then(|e| e.metadata()).map(|m| {
size += if m.is_dir() { 0 } else { m.len() };
}) {
warn!("ignoring error {}", e);
warn!("ignoring error {err}");
}
}
Ok(Some(size))
Expand Down Expand Up @@ -656,8 +656,8 @@ fn map_entry(
let links = if m.is_dir() { 0 } else { m.nlink() };

let extended_attributes = match list_extended_attributes(entry.path()) {
Err(e) => {
warn!("ignoring error: {e}\n");
Err(err) => {
warn!("ignoring error: {err}");
vec![]
}
Ok(xattr_list) => xattr_list,
Expand Down
4 changes: 2 additions & 2 deletions crates/core/src/commands/backup.rs
Original file line number Diff line number Diff line change
Expand Up @@ -267,7 +267,7 @@ pub(crate) fn backup<P: ProgressBars, S: IndexedIds>(
let (parent_id, parent) = opts.parent_opts.get_parent(repo, &snap, backup_stdin);
match parent_id {
Some(id) => {
info!("using parent {}", id);
info!("using parent {id}");
snap.parent = Some(id);
}
None => {
Expand All @@ -276,7 +276,7 @@ pub(crate) fn backup<P: ProgressBars, S: IndexedIds>(
};

let be = DryRunBackend::new(repo.dbe().clone(), opts.dry_run);
info!("starting to backup {source}...");
info!("starting to backup {source} ...");
let archiver = Archiver::new(be, index, repo.config(), parent, snap)?;
let p = repo.pb.progress_bytes("backing up...");

Expand Down
28 changes: 14 additions & 14 deletions crates/core/src/commands/check.rs
Original file line number Diff line number Diff line change
Expand Up @@ -274,7 +274,10 @@ pub(crate) fn check_repository<P: ProgressBars, S: Open>(
.map(|(id, size)| (**id, *size))
.collect();
if let Err(err) = cache.remove_not_in_list(FileType::Pack, &ids) {
warn!("Error in cache backend removing pack files: {err}");
warn!(
"Error in cache backend removing pack files: {}",
err.display_log()
);
}
p.finish();

Expand Down Expand Up @@ -309,21 +312,13 @@ pub(crate) fn check_repository<P: ProgressBars, S: Open>(
let data = match be.read_full(FileType::Pack, &id) {
Ok(data) => data,
Err(err) => {
// FIXME: This needs different handling, now it prints a full display of RusticError
// Instead we should actually collect and return a list of errors on the happy path
// for `Check`, as this is a non-critical operation and we want to show all errors
// to the user.
error!("Error reading data for pack {id} : {err}");
error!("Error reading data for pack {id} : {}", err.display_log());
return;
}
};
match check_pack(be, pack, data, &p) {
Ok(()) => {}
// FIXME: This needs different handling, now it prints a full display of RusticError
// Instead we should actually collect and return a list of errors on the happy path
// for `Check`, as this is a non-critical operation and we want to show all errors
// to the user.
Err(err) => error!("Pack {id} is not valid: {err}",),
Err(err) => error!("Pack {id} is not valid: {}", err.display_log()),
}
});
p.finish();
Expand Down Expand Up @@ -362,7 +357,6 @@ fn check_hot_files(
match files.remove(&id) {
None => error!("hot file Type: {file_type:?}, Id: {id} does not exist in repo"),
Some(size) if size != size_hot => {
// TODO: This should be an actual error not a log entry
error!("Type: {file_type:?}, Id: {id}: hot size: {size_hot}, actual size: {size}");
}
_ => {} //everything ok
Expand Down Expand Up @@ -415,10 +409,16 @@ fn check_cache_files(
be.read_full(file_type, &id),
) {
(Err(err), _) => {
error!("Error reading cached file Type: {file_type:?}, Id: {id} : {err}");
error!(
"Error reading cached file Type: {file_type:?}, Id: {id} : {}",
err.display_log()
);
}
(_, Err(err)) => {
error!("Error reading file Type: {file_type:?}, Id: {id} : {err}");
error!(
"Error reading file Type: {file_type:?}, Id: {id} : {}",
err.display_log()
);
}
(Ok(Some(data_cached)), Ok(data)) if data_cached != data => {
error!(
Expand Down
5 changes: 4 additions & 1 deletion crates/core/src/commands/repair/index.rs
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,10 @@ pub(crate) fn repair_index<P: ProgressBars, S: Open>(
debug!("reading pack {id}...");
match PackHeader::from_file(be, id, size_hint, packsize) {
Err(err) => {
warn!("error reading pack {id} (-> removing from index): {err}");
warn!(
"error reading pack {id} (-> removing from index): {}",
err.display_log()
);
}
Ok(header) => {
let pack = IndexPack {
Expand Down
4 changes: 2 additions & 2 deletions crates/core/src/commands/repair/snapshots.rs
Original file line number Diff line number Diff line change
Expand Up @@ -213,8 +213,8 @@ pub(crate) fn repair_tree<BE: DecryptWriteBackend>(
}

let (tree, mut changed) = Tree::from_backend(be, index, id).map_or_else(
|_err| {
warn!("tree {id} could not be loaded.");
|err| {
warn!("tree {id} could not be loaded: {}", err.display_log());
(Tree::new(), Changed::This)
},
|tree| (tree, Changed::None),
Expand Down
Loading

0 comments on commit c5ecc23

Please sign in to comment.