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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
use super::Error;
use crate::ast::{EnumVariant, Ident};
use crate::diag::{Diagnostic, DiagnosticKind, Formatted, Formatter};
use crate::validate::Validate;
use crate::{Parsed, Span};

#[derive(Debug)]
pub struct EmptyEnum {
    schema_name: String,
    span: Span,
    ident: Option<Ident>,
}

impl EmptyEnum {
    pub(crate) fn validate(
        vars: &[EnumVariant],
        span: Span,
        ident: Option<&Ident>,
        validate: &mut Validate,
    ) {
        if !vars.is_empty() {
            return;
        }

        validate.add_error(EmptyEnum {
            schema_name: validate.schema_name().to_owned(),
            span,
            ident: ident.cloned(),
        });
    }

    pub fn span(&self) -> Span {
        self.span
    }

    pub fn ident(&self) -> Option<&Ident> {
        self.ident.as_ref()
    }
}

impl Diagnostic for EmptyEnum {
    fn kind(&self) -> DiagnosticKind {
        DiagnosticKind::Error
    }

    fn schema_name(&self) -> &str {
        &self.schema_name
    }

    fn format<'a>(&'a self, parsed: &'a Parsed) -> Formatted<'a> {
        let mut fmt = if let Some(ref ident) = self.ident {
            Formatter::new(self, format!("empty enum `{}`", ident.value()))
        } else {
            Formatter::new(self, "empty inline enum")
        };

        if let Some(schema) = parsed.get_schema(&self.schema_name) {
            fmt.main_block(schema, self.span.from, self.span, "");
        }

        fmt.note("empty enums are not supported")
            .help("add at least one variant to the enum");
        fmt.format()
    }
}

impl From<EmptyEnum> for Error {
    fn from(e: EmptyEnum) -> Self {
        Error::EmptyEnum(e)
    }
}