refactor(tvix/store/proto): use bstr::ByteSlice
String::from_utf8_lossy simply discards invalid bytes, while bstr replaces them with their replacement character. Change-Id: Ib78ff36ca5faacc1ad60bc4ddde7b62773848c07 Reviewed-on: https://cl.tvl.fyi/c/depot/+/10981 Tested-by: BuildkiteCI Reviewed-by: Peter Kolloch <info@eigenvalue.net> Reviewed-by: flokli <flokli@flokli.de>
This commit is contained in:
		
							parent
							
								
									98a17dbdf9
								
							
						
					
					
						commit
						43570bae11
					
				
					 4 changed files with 8 additions and 1 deletions
				
			
		
							
								
								
									
										1
									
								
								tvix/Cargo.lock
									
										
									
										generated
									
									
									
								
							
							
						
						
									
										1
									
								
								tvix/Cargo.lock
									
										
									
										generated
									
									
									
								
							|  | @ -3417,6 +3417,7 @@ dependencies = [ | |||
|  "async-recursion", | ||||
|  "async-stream", | ||||
|  "blake3", | ||||
|  "bstr", | ||||
|  "bytes", | ||||
|  "clap", | ||||
|  "count-write", | ||||
|  |  | |||
|  | @ -10788,6 +10788,10 @@ rec { | |||
|             packageId = "blake3"; | ||||
|             features = [ "rayon" "std" ]; | ||||
|           } | ||||
|           { | ||||
|             name = "bstr"; | ||||
|             packageId = "bstr"; | ||||
|           } | ||||
|           { | ||||
|             name = "bytes"; | ||||
|             packageId = "bytes"; | ||||
|  |  | |||
|  | @ -7,6 +7,7 @@ edition = "2021" | |||
| anyhow = "1.0.68" | ||||
| async-stream = "0.3.5" | ||||
| blake3 = { version = "1.3.1", features = ["rayon", "std"] } | ||||
| bstr = "1.6.0" | ||||
| bytes = "1.4.0" | ||||
| clap = { version = "4.0", features = ["derive", "env"] } | ||||
| count-write = "0.1.0" | ||||
|  |  | |||
|  | @ -1,4 +1,5 @@ | |||
| #![allow(clippy::derive_partial_eq_without_eq, non_snake_case)] | ||||
| use bstr::ByteSlice; | ||||
| use bytes::Bytes; | ||||
| use data_encoding::BASE64; | ||||
| // https://github.com/hyperium/tonic/issues/1056
 | ||||
|  | @ -41,7 +42,7 @@ pub enum ValidatePathInfoError { | |||
|     InvalidRootNode(ValidateNodeError), | ||||
| 
 | ||||
|     /// Invalid node name encountered. Root nodes in PathInfos have more strict name requirements
 | ||||
|     #[error("Failed to parse {} as StorePath: {1}", String::from_utf8_lossy(.0))] | ||||
|     #[error("Failed to parse {} as StorePath: {1}", .0.to_str_lossy())] | ||||
|     InvalidNodeName(Vec<u8>, store_path::Error), | ||||
| 
 | ||||
|     /// The digest in narinfo.nar_sha256 has an invalid len.
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue