refactor(nix-compat/nixhash/ca_hash): inline algo_str
This is only used in to_nix_nixbase32_string, and in one place in narinfo2parquet (though it might be sliced wrongly there too). This is a partial revert of cl/12041, at least for the narinfo2parquet parts. Change-Id: Ic8c57373f7ab79043a491267e8484fa8399cea04 Reviewed-on: https://cl.snix.dev/c/snix/+/30564 Tested-by: besadii Autosubmit: Florian Klink <flokli@flokli.de> Reviewed-by: edef <edef@edef.eu>
This commit is contained in:
		
							parent
							
								
									63036b3c5e
								
							
						
					
					
						commit
						b90da345ab
					
				
					 2 changed files with 36 additions and 23 deletions
				
			
		|  | @ -12,6 +12,7 @@ use jemallocator::Jemalloc; | |||
| use nix_compat::{ | ||||
|     narinfo::{self, NarInfo}, | ||||
|     nixbase32, | ||||
|     nixhash::{CAHash, NixHash}, | ||||
| }; | ||||
| use polars::{io::parquet::ParquetWriter, prelude::*}; | ||||
| use std::{ | ||||
|  | @ -192,8 +193,26 @@ impl FrameBuilder { | |||
|             })); | ||||
| 
 | ||||
|         if let Some(ca) = &entry.ca { | ||||
|             self.ca_algo.append_value(ca.algo_str()); | ||||
|             self.ca_hash.append_value(ca.hash().digest_as_bytes()); | ||||
|             // decompose the CAHash into algo and hash parts
 | ||||
|             // TODO(edef): split this up differently?
 | ||||
|             let (algo, hash) = match ca { | ||||
|                 CAHash::Flat(h) => match h { | ||||
|                     NixHash::Md5(h) => ("fixed:md5", &h[..]), | ||||
|                     NixHash::Sha1(h) => ("fixed:sha1", &h[..]), | ||||
|                     NixHash::Sha256(h) => ("fixed:sha256", &h[..]), | ||||
|                     NixHash::Sha512(h) => ("fixed:sha512", &h[..]), | ||||
|                 }, | ||||
|                 CAHash::Nar(h) => match h { | ||||
|                     NixHash::Md5(h) => ("fixed:r:md5", &h[..]), | ||||
|                     NixHash::Sha1(h) => ("fixed:r:sha1", &h[..]), | ||||
|                     NixHash::Sha256(h) => ("fixed:r:sha256", &h[..]), | ||||
|                     NixHash::Sha512(h) => ("fixed:r:sha512", &h[..]), | ||||
|                 }, | ||||
|                 CAHash::Text(h) => ("text:sha256", &h[..]), | ||||
|             }; | ||||
| 
 | ||||
|             self.ca_algo.append_value(algo); | ||||
|             self.ca_hash.append_value(hash); | ||||
|         } else { | ||||
|             self.ca_algo.append_null(); | ||||
|             self.ca_hash.append_null(); | ||||
|  |  | |||
|  | @ -47,26 +47,6 @@ impl CAHash { | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /// Returns a colon-separated string consisting of mode, recursiveness and
 | ||||
|     /// hash algo. Used as a prefix in various string representations.
 | ||||
|     pub fn algo_str(&self) -> &'static str { | ||||
|         match self.mode() { | ||||
|             HashMode::Flat => match self.hash().as_ref() { | ||||
|                 NixHash::Md5(_) => "fixed:md5", | ||||
|                 NixHash::Sha1(_) => "fixed:sha1", | ||||
|                 NixHash::Sha256(_) => "fixed:sha256", | ||||
|                 NixHash::Sha512(_) => "fixed:sha512", | ||||
|             }, | ||||
|             HashMode::Nar => match self.hash().as_ref() { | ||||
|                 NixHash::Md5(_) => "fixed:r:md5", | ||||
|                 NixHash::Sha1(_) => "fixed:r:sha1", | ||||
|                 NixHash::Sha256(_) => "fixed:r:sha256", | ||||
|                 NixHash::Sha512(_) => "fixed:r:sha512", | ||||
|             }, | ||||
|             HashMode::Text => "text:sha256", | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /// Constructs a [CAHash] from the textual representation,
 | ||||
|     /// which is one of the three:
 | ||||
|     /// - `text:sha256:$nixbase32sha256digest`
 | ||||
|  | @ -99,7 +79,21 @@ impl CAHash { | |||
|     pub fn to_nix_nixbase32_string(&self) -> String { | ||||
|         format!( | ||||
|             "{}:{}", | ||||
|             self.algo_str(), | ||||
|             match self.mode() { | ||||
|                 HashMode::Flat => match self.hash().as_ref() { | ||||
|                     NixHash::Md5(_) => "fixed:md5", | ||||
|                     NixHash::Sha1(_) => "fixed:sha1", | ||||
|                     NixHash::Sha256(_) => "fixed:sha256", | ||||
|                     NixHash::Sha512(_) => "fixed:sha512", | ||||
|                 }, | ||||
|                 HashMode::Nar => match self.hash().as_ref() { | ||||
|                     NixHash::Md5(_) => "fixed:r:md5", | ||||
|                     NixHash::Sha1(_) => "fixed:r:sha1", | ||||
|                     NixHash::Sha256(_) => "fixed:r:sha256", | ||||
|                     NixHash::Sha512(_) => "fixed:r:sha512", | ||||
|                 }, | ||||
|                 HashMode::Text => "text:sha256", | ||||
|             }, | ||||
|             nixbase32::encode(self.hash().digest_as_bytes()) | ||||
|         ) | ||||
|     } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue