about summary refs log tree commit diff
path: root/tvix/cli/src/errors.rs
blob: cbf8ed94579d1dcee8585d56cc7bf07a5db7b6d5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
use std::{error, fmt::Display, rc::Rc};
use tvix_derivation::DerivationError;

#[derive(Debug)]
pub enum Error {
    // Errors related to derivation construction
    DuplicateOutput(String),
    ConflictingOutputTypes,
    DuplicateEnvVar(String),
    ShadowedOutput(String),
    InvalidDerivation(DerivationError),
    InvalidOutputHashMode(String),
}

impl Display for Error {
    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
        match self {
            Error::DuplicateOutput(name) => {
                write!(f, "an output with the name '{name}' is already defined")
            }

            Error::ConflictingOutputTypes => write!(
                f,
                "fixed-output derivations can only have the default `out`-output"
            ),

            Error::DuplicateEnvVar(name) => write!(
                f,
                "the environment variable '{name}' has already been set in this derivation"
            ),
            Error::ShadowedOutput(name) => write!(
                f,
                "the environment variable '{name}' shadows the name of an output"
            ),
            Error::InvalidDerivation(error) => write!(f, "invalid derivation parameters: {error}"),

            Error::InvalidOutputHashMode(mode) => write!(
                f,
                "invalid output hash mode: '{mode}', only 'recursive' and 'flat` are supported"
            ),
        }
    }
}

impl error::Error for Error {
    fn source(&self) -> Option<&(dyn error::Error + 'static)> {
        None
    }
}

impl From<Error> for tvix_eval::ErrorKind {
    fn from(err: Error) -> Self {
        tvix_eval::ErrorKind::TvixError(Rc::new(err))
    }
}