133d722a9Sopenharmony_ciuse crate::syntax::qualified::QualifiedName;
233d722a9Sopenharmony_ciuse quote::IdentFragment;
333d722a9Sopenharmony_ciuse std::fmt::{self, Display};
433d722a9Sopenharmony_ciuse std::iter::FromIterator;
533d722a9Sopenharmony_ciuse std::slice::Iter;
633d722a9Sopenharmony_ciuse syn::parse::{Error, Parse, ParseStream, Result};
733d722a9Sopenharmony_ciuse syn::{Expr, Ident, Lit, Meta, Token};
833d722a9Sopenharmony_ci
933d722a9Sopenharmony_cimod kw {
1033d722a9Sopenharmony_ci    syn::custom_keyword!(namespace);
1133d722a9Sopenharmony_ci}
1233d722a9Sopenharmony_ci
1333d722a9Sopenharmony_ci#[derive(Clone, Default)]
1433d722a9Sopenharmony_cipub struct Namespace {
1533d722a9Sopenharmony_ci    segments: Vec<Ident>,
1633d722a9Sopenharmony_ci}
1733d722a9Sopenharmony_ci
1833d722a9Sopenharmony_ciimpl Namespace {
1933d722a9Sopenharmony_ci    pub const ROOT: Self = Namespace {
2033d722a9Sopenharmony_ci        segments: Vec::new(),
2133d722a9Sopenharmony_ci    };
2233d722a9Sopenharmony_ci
2333d722a9Sopenharmony_ci    pub fn iter(&self) -> Iter<Ident> {
2433d722a9Sopenharmony_ci        self.segments.iter()
2533d722a9Sopenharmony_ci    }
2633d722a9Sopenharmony_ci
2733d722a9Sopenharmony_ci    pub fn parse_bridge_attr_namespace(input: ParseStream) -> Result<Self> {
2833d722a9Sopenharmony_ci        if input.is_empty() {
2933d722a9Sopenharmony_ci            return Ok(Namespace::ROOT);
3033d722a9Sopenharmony_ci        }
3133d722a9Sopenharmony_ci
3233d722a9Sopenharmony_ci        input.parse::<kw::namespace>()?;
3333d722a9Sopenharmony_ci        input.parse::<Token![=]>()?;
3433d722a9Sopenharmony_ci        let namespace = input.parse::<Namespace>()?;
3533d722a9Sopenharmony_ci        input.parse::<Option<Token![,]>>()?;
3633d722a9Sopenharmony_ci        Ok(namespace)
3733d722a9Sopenharmony_ci    }
3833d722a9Sopenharmony_ci
3933d722a9Sopenharmony_ci    pub fn parse_meta(meta: &Meta) -> Result<Self> {
4033d722a9Sopenharmony_ci        if let Meta::NameValue(meta) = meta {
4133d722a9Sopenharmony_ci            match &meta.value {
4233d722a9Sopenharmony_ci                Expr::Lit(expr) => {
4333d722a9Sopenharmony_ci                    if let Lit::Str(lit) = &expr.lit {
4433d722a9Sopenharmony_ci                        let segments = QualifiedName::parse_quoted(lit)?.segments;
4533d722a9Sopenharmony_ci                        return Ok(Namespace { segments });
4633d722a9Sopenharmony_ci                    }
4733d722a9Sopenharmony_ci                }
4833d722a9Sopenharmony_ci                Expr::Path(expr)
4933d722a9Sopenharmony_ci                    if expr.qself.is_none()
5033d722a9Sopenharmony_ci                        && expr
5133d722a9Sopenharmony_ci                            .path
5233d722a9Sopenharmony_ci                            .segments
5333d722a9Sopenharmony_ci                            .iter()
5433d722a9Sopenharmony_ci                            .all(|segment| segment.arguments.is_none()) =>
5533d722a9Sopenharmony_ci                {
5633d722a9Sopenharmony_ci                    let segments = expr
5733d722a9Sopenharmony_ci                        .path
5833d722a9Sopenharmony_ci                        .segments
5933d722a9Sopenharmony_ci                        .iter()
6033d722a9Sopenharmony_ci                        .map(|segment| segment.ident.clone())
6133d722a9Sopenharmony_ci                        .collect();
6233d722a9Sopenharmony_ci                    return Ok(Namespace { segments });
6333d722a9Sopenharmony_ci                }
6433d722a9Sopenharmony_ci                _ => {}
6533d722a9Sopenharmony_ci            }
6633d722a9Sopenharmony_ci        }
6733d722a9Sopenharmony_ci        Err(Error::new_spanned(meta, "unsupported namespace attribute"))
6833d722a9Sopenharmony_ci    }
6933d722a9Sopenharmony_ci}
7033d722a9Sopenharmony_ci
7133d722a9Sopenharmony_ciimpl Default for &Namespace {
7233d722a9Sopenharmony_ci    fn default() -> Self {
7333d722a9Sopenharmony_ci        const ROOT: &Namespace = &Namespace::ROOT;
7433d722a9Sopenharmony_ci        ROOT
7533d722a9Sopenharmony_ci    }
7633d722a9Sopenharmony_ci}
7733d722a9Sopenharmony_ci
7833d722a9Sopenharmony_ciimpl Parse for Namespace {
7933d722a9Sopenharmony_ci    fn parse(input: ParseStream) -> Result<Self> {
8033d722a9Sopenharmony_ci        let segments = QualifiedName::parse_quoted_or_unquoted(input)?.segments;
8133d722a9Sopenharmony_ci        Ok(Namespace { segments })
8233d722a9Sopenharmony_ci    }
8333d722a9Sopenharmony_ci}
8433d722a9Sopenharmony_ci
8533d722a9Sopenharmony_ciimpl Display for Namespace {
8633d722a9Sopenharmony_ci    fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
8733d722a9Sopenharmony_ci        for segment in self {
8833d722a9Sopenharmony_ci            write!(f, "{}$", segment)?;
8933d722a9Sopenharmony_ci        }
9033d722a9Sopenharmony_ci        Ok(())
9133d722a9Sopenharmony_ci    }
9233d722a9Sopenharmony_ci}
9333d722a9Sopenharmony_ci
9433d722a9Sopenharmony_ciimpl IdentFragment for Namespace {
9533d722a9Sopenharmony_ci    fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
9633d722a9Sopenharmony_ci        Display::fmt(self, f)
9733d722a9Sopenharmony_ci    }
9833d722a9Sopenharmony_ci}
9933d722a9Sopenharmony_ci
10033d722a9Sopenharmony_ciimpl<'a> IntoIterator for &'a Namespace {
10133d722a9Sopenharmony_ci    type Item = &'a Ident;
10233d722a9Sopenharmony_ci    type IntoIter = Iter<'a, Ident>;
10333d722a9Sopenharmony_ci    fn into_iter(self) -> Self::IntoIter {
10433d722a9Sopenharmony_ci        self.iter()
10533d722a9Sopenharmony_ci    }
10633d722a9Sopenharmony_ci}
10733d722a9Sopenharmony_ci
10833d722a9Sopenharmony_ciimpl<'a> FromIterator<&'a Ident> for Namespace {
10933d722a9Sopenharmony_ci    fn from_iter<I>(idents: I) -> Self
11033d722a9Sopenharmony_ci    where
11133d722a9Sopenharmony_ci        I: IntoIterator<Item = &'a Ident>,
11233d722a9Sopenharmony_ci    {
11333d722a9Sopenharmony_ci        let segments = idents.into_iter().cloned().collect();
11433d722a9Sopenharmony_ci        Namespace { segments }
11533d722a9Sopenharmony_ci    }
11633d722a9Sopenharmony_ci}
117