diff options
author | Florian Klink <flokli@flokli.de> | 2023-03-29T23·11+0200 |
---|---|---|
committer | clbot <clbot@tvl.fyi> | 2023-03-30T13·47+0000 |
commit | 14c5781389838f05f3f0063e8c7f04b1eeceaf2e (patch) | |
tree | b38482d57d285dba8b3f4f8268b73adf30f3d1e6 /tvix/nix-compat/src/nixhash.rs | |
parent | e53152866ed975fafb59634321d6228cc29b3d82 (diff) |
refactor(tvix/nix-compat): move HashAlgo to separate file r/6056
… and keep the pub exports as is. Change-Id: I2ad21660577553395f05b5ba71083626429b0dfc Reviewed-on: https://cl.tvl.fyi/c/depot/+/8363 Tested-by: BuildkiteCI Reviewed-by: tazjin <tazjin@tvl.su> Autosubmit: flokli <flokli@flokli.de>
Diffstat (limited to 'tvix/nix-compat/src/nixhash.rs')
-rw-r--r-- | tvix/nix-compat/src/nixhash.rs | 40 |
1 files changed, 2 insertions, 38 deletions
diff --git a/tvix/nix-compat/src/nixhash.rs b/tvix/nix-compat/src/nixhash.rs index 69ed98ff962e..0c7637c60a5e 100644 --- a/tvix/nix-compat/src/nixhash.rs +++ b/tvix/nix-compat/src/nixhash.rs @@ -1,10 +1,8 @@ +use crate::nixbase32; use data_encoding::{BASE64, BASE64_NOPAD, HEXLOWER}; -use serde::{Deserialize, Serialize}; -use std::fmt::Display; use thiserror::Error; -use crate::nixbase32; - +pub use crate::nixhash_algos::HashAlgo; pub use crate::nixhash_with_mode::NixHashWithMode; /// Nix allows specifying hashes in various encodings, and magically just @@ -29,40 +27,6 @@ impl NixHash { } } -/// This are the hash algorithms supported by cppnix. -#[derive(Clone, Debug, Eq, PartialEq, Serialize, Deserialize)] -pub enum HashAlgo { - Md5, - Sha1, - Sha256, - Sha512, -} - -impl Display for HashAlgo { - fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - match &self { - HashAlgo::Md5 => write!(f, "md5"), - HashAlgo::Sha1 => write!(f, "sha1"), - HashAlgo::Sha256 => write!(f, "sha256"), - HashAlgo::Sha512 => write!(f, "sha512"), - } - } -} - -impl TryFrom<&str> for HashAlgo { - type Error = Error; - - fn try_from(algo_str: &str) -> Result<Self, Self::Error> { - match algo_str { - "md5" => Ok(Self::Md5), - "sha1" => Ok(Self::Sha1), - "sha256" => Ok(Self::Sha256), - "sha512" => Ok(Self::Sha512), - _ => Err(Error::InvalidAlgo(algo_str.to_string())), - } - } -} - /// Errors related to NixHash construction. #[derive(Debug, Error)] pub enum Error { |