oxilean_codegen/scala_backend/
scalacaseclass_traits.rs1use 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}