diff options
Diffstat (limited to 'tvix/glue/src/builtins/derivation_error.rs')
-rw-r--r-- | tvix/glue/src/builtins/derivation_error.rs | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/tvix/glue/src/builtins/derivation_error.rs b/tvix/glue/src/builtins/derivation_error.rs new file mode 100644 index 000000000000..25471f0fdf48 --- /dev/null +++ b/tvix/glue/src/builtins/derivation_error.rs @@ -0,0 +1,27 @@ +//! Contains [crate::builtins::DerivationError]. +use nix_compat::{derivation::DerivationError, nixhash}; +use std::rc::Rc; +use thiserror::Error; + +/// Errors related to derivation construction +#[derive(Debug, Error)] +pub enum Error { + #[error("an output with the name '{0}' is already defined")] + DuplicateOutput(String), + #[error("fixed-output derivations can only have the default `out`-output")] + ConflictingOutputTypes, + #[error("the environment variable '{0}' has already been set in this derivation")] + DuplicateEnvVar(String), + #[error("invalid derivation parameters: {0}")] + InvalidDerivation(DerivationError), + #[error("invalid output hash: {0}")] + InvalidOutputHash(nixhash::Error), + #[error("invalid output hash mode: '{0}', only 'recursive' and 'flat` are supported")] + InvalidOutputHashMode(String), +} + +impl From<Error> for tvix_eval::ErrorKind { + fn from(err: Error) -> Self { + tvix_eval::ErrorKind::TvixError(Rc::new(err)) + } +} |