refactor(snix/castore/import): destructure more directly
Destructuring by value gives us ownership of the data we need, without needing unnecessary clones. We previously avoided this because we wanted to call IngestionEntry::path, but inlining that into our match is cleaner. Change-Id: Id58075a98929306e99706746b6e4a9f961a24faf Reviewed-on: https://cl.snix.dev/c/snix/+/30239 Tested-by: besadii Reviewed-by: Florian Klink <flokli@flokli.de>
This commit is contained in:
		
							parent
							
								
									1f70de459d
								
							
						
					
					
						commit
						86456a3334
					
				
					 1 changed files with 40 additions and 37 deletions
				
			
		|  | @ -6,7 +6,7 @@ | ||||||
| 
 | 
 | ||||||
| use crate::directoryservice::{DirectoryPutter, DirectoryService}; | use crate::directoryservice::{DirectoryPutter, DirectoryService}; | ||||||
| use crate::path::{Path, PathBuf}; | use crate::path::{Path, PathBuf}; | ||||||
| use crate::{B3Digest, Directory, Node, SymlinkTargetError}; | use crate::{B3Digest, Directory, Node}; | ||||||
| use futures::{Stream, StreamExt}; | use futures::{Stream, StreamExt}; | ||||||
| use tracing::Level; | use tracing::Level; | ||||||
| 
 | 
 | ||||||
|  | @ -52,21 +52,21 @@ where | ||||||
|     let mut maybe_directory_putter: Option<Box<dyn DirectoryPutter>> = None; |     let mut maybe_directory_putter: Option<Box<dyn DirectoryPutter>> = None; | ||||||
| 
 | 
 | ||||||
|     let root_node = loop { |     let root_node = loop { | ||||||
|         let mut entry = entries |         let entry = entries | ||||||
|             .next() |             .next() | ||||||
|             .await |             .await | ||||||
|             // The last entry of the stream must have 1 path component, after which
 |             // The last entry of the stream must have 1 path component, after which
 | ||||||
|             // we break the loop manually.
 |             // we break the loop manually.
 | ||||||
|             .ok_or(IngestionError::UnexpectedEndOfStream)??; |             .ok_or(IngestionError::UnexpectedEndOfStream)??; | ||||||
| 
 | 
 | ||||||
|         let node = match &mut entry { |         let (path, node) = match entry { | ||||||
|             IngestionEntry::Dir { .. } => { |             IngestionEntry::Dir { path } => { | ||||||
|                 // If the entry is a directory, we traversed all its children (and
 |                 // If the entry is a directory, we traversed all its children (and
 | ||||||
|                 // populated it in `directories`).
 |                 // populated it in `directories`).
 | ||||||
|                 // If we don't have it in directories, it's a directory without
 |                 // If we don't have it in directories, it's a directory without
 | ||||||
|                 // children.
 |                 // children.
 | ||||||
|                 let directory = directories |                 let directory = directories | ||||||
|                     .remove(entry.path()) |                     .remove(&path) | ||||||
|                     // In that case, it contained no children
 |                     // In that case, it contained no children
 | ||||||
|                     .unwrap_or_default(); |                     .unwrap_or_default(); | ||||||
| 
 | 
 | ||||||
|  | @ -76,51 +76,54 @@ where | ||||||
|                 // Use the directory_putter to upload the directory.
 |                 // Use the directory_putter to upload the directory.
 | ||||||
|                 // If we don't have one yet (as that's the first one to upload),
 |                 // If we don't have one yet (as that's the first one to upload),
 | ||||||
|                 // initialize the putter.
 |                 // initialize the putter.
 | ||||||
|                 maybe_directory_putter |                 let directory_putter = maybe_directory_putter | ||||||
|                     .get_or_insert_with(|| directory_service.put_multiple_start()) |                     .get_or_insert_with(|| directory_service.put_multiple_start()); | ||||||
|                     .put(directory) |  | ||||||
|                     .await |  | ||||||
|                     .map_err(|e| { |  | ||||||
|                         IngestionError::UploadDirectoryError(entry.path().to_owned(), e) |  | ||||||
|                     })?; |  | ||||||
| 
 | 
 | ||||||
|  |                 match directory_putter.put(directory).await { | ||||||
|  |                     Ok(()) => ( | ||||||
|  |                         path, | ||||||
|                         Node::Directory { |                         Node::Directory { | ||||||
|                             digest: directory_digest, |                             digest: directory_digest, | ||||||
|                             size: directory_size, |                             size: directory_size, | ||||||
|  |                         }, | ||||||
|  |                     ), | ||||||
|  |                     Err(e) => { | ||||||
|  |                         return Err(IngestionError::UploadDirectoryError(path, e)); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             &mut IngestionEntry::Symlink { ref target, .. } => Node::Symlink { |             } | ||||||
|                 target: bytes::Bytes::copy_from_slice(target).try_into().map_err( |             IngestionEntry::Symlink { path, target } => { | ||||||
|                     |e: SymlinkTargetError| { |                 match bytes::Bytes::from(target).try_into() { | ||||||
|                         IngestionError::UploadDirectoryError( |                     Ok(target) => (path, Node::Symlink { target }), | ||||||
|                             entry.path().to_owned(), |                     Err(e) => { | ||||||
|  |                         return Err(IngestionError::UploadDirectoryError( | ||||||
|  |                             path, | ||||||
|                             crate::Error::StorageError(format!("invalid symlink target: {}", e)), |                             crate::Error::StorageError(format!("invalid symlink target: {}", e)), | ||||||
|                         ) |                         )); | ||||||
|                     }, |                     } | ||||||
|                 )?, |                 } | ||||||
|             }, |             } | ||||||
|             IngestionEntry::Regular { |             IngestionEntry::Regular { | ||||||
|  |                 path, | ||||||
|                 size, |                 size, | ||||||
|                 executable, |                 executable, | ||||||
|                 digest, |                 digest, | ||||||
|                 .. |             } => ( | ||||||
|             } => Node::File { |                 path, | ||||||
|  |                 Node::File { | ||||||
|                     digest: digest.clone(), |                     digest: digest.clone(), | ||||||
|                 size: *size, |                     size, | ||||||
|                 executable: *executable, |                     executable, | ||||||
|                 }, |                 }, | ||||||
|  |             ), | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         let parent = entry |         let parent = path.parent().expect("Snix bug: got entry with root node"); | ||||||
|             .path() |  | ||||||
|             .parent() |  | ||||||
|             .expect("Snix bug: got entry with root node"); |  | ||||||
| 
 | 
 | ||||||
|         if parent == crate::Path::ROOT { |         if parent == crate::Path::ROOT { | ||||||
|             break node; |             break node; | ||||||
|         } else { |         } else { | ||||||
|             let name = entry |             let name = path | ||||||
|                 .path() |  | ||||||
|                 .file_name() |                 .file_name() | ||||||
|                 // If this is the root node, it will have an empty name.
 |                 // If this is the root node, it will have an empty name.
 | ||||||
|                 .unwrap_or_else(|| "".try_into().unwrap()) |                 .unwrap_or_else(|| "".try_into().unwrap()) | ||||||
|  | @ -133,7 +136,7 @@ where | ||||||
|                 .add(name, node) |                 .add(name, node) | ||||||
|                 .map_err(|e| { |                 .map_err(|e| { | ||||||
|                     IngestionError::UploadDirectoryError( |                     IngestionError::UploadDirectoryError( | ||||||
|                         entry.path().to_owned(), |                         path, | ||||||
|                         crate::Error::StorageError(e.to_string()), |                         crate::Error::StorageError(e.to_string()), | ||||||
|                     ) |                     ) | ||||||
|                 })?; |                 })?; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue