Skip to main content

oxilean_codegen/scala_backend/
scalacaseclass_traits.rs

1//! # ScalaCaseClass - Trait Implementations
2//!
3//! This module contains trait implementations for `ScalaCaseClass`.
4//!
5//! ## Implemented Traits
6//!
7//! - `Display`
8//!
9//! 🤖 Generated with [SplitRS](https://github.com/cool-japan/splitrs)
10
11use crate::lcnf::*;
12
13use super::types::ScalaCaseClass;
14use std::fmt;
15
16impl fmt::Display for ScalaCaseClass {
17    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
18        write!(f, "case class {}", self.name)?;
19        if !self.type_params.is_empty() {
20            write!(f, "[")?;
21            for (i, tp) in self.type_params.iter().enumerate() {
22                if i > 0 {
23                    write!(f, ", ")?;
24                }
25                write!(f, "{}", tp)?;
26            }
27            write!(f, "]")?;
28        }
29        write!(f, "(")?;
30        for (i, field) in self.fields.iter().enumerate() {
31            if i > 0 {
32                write!(f, ", ")?;
33            }
34            write!(f, "{}", field)?;
35        }
36        write!(f, ")")?;
37        if !self.extends_list.is_empty() {
38            write!(f, " extends {}", self.extends_list[0])?;
39            for e in &self.extends_list[1..] {
40                write!(f, " with {}", e)?;
41            }
42        }
43        Ok(())
44    }
45}