diff --git a/src/applications/analysis.rs b/src/applications/analysis.rs index 5994b1b..13e4569 100644 --- a/src/applications/analysis.rs +++ b/src/applications/analysis.rs @@ -49,12 +49,11 @@ pub fn get_damage_analysis(calculator_config: PyCalculatorConfig) -> PyResult config.as_ref(py).repr()?.to_str()?.to_string(), None => "None".to_string(), }; - Ok(format!("BuffInterface(name={}, config={})", name, config_repr)) + Ok(format!( + "BuffInterface(name={}, config={})", + name, config_repr + )) } #[getter] diff --git a/src/applications/input/calculator.rs b/src/applications/input/calculator.rs index bfaa951..dcf25d9 100644 --- a/src/applications/input/calculator.rs +++ b/src/applications/input/calculator.rs @@ -6,7 +6,7 @@ use crate::applications::input::skill::PySkillInterface; use crate::applications::input::weapon::PyWeaponInterface; use pyo3::prelude::*; -use pyo3::types::PyDict; +use pyo3::types::{PyDict, PyList}; #[pyclass(name = "CalculatorConfig")] #[derive(Clone)] @@ -50,4 +50,35 @@ impl PyCalculatorConfig { enemy, }) } + + #[getter] + pub fn __dict__(&self, py: Python) -> PyResult { + let dict = PyDict::new(py); + dict.set_item("character", self.character.__dict__(py)?)?; + dict.set_item("weapon", self.weapon.__dict__(py)?)?; + let buffs = self + .buffs + .iter() + .map(|b| b.__dict__(py)) + .collect::, PyErr>>()?; + dict.set_item("buffs", PyList::new(py, buffs))?; + let artifacts = self + .artifacts + .iter() + .map(|ar| ar.__dict__(py)) + .collect::, PyErr>>()?; + dict.set_item("artifacts", PyList::new(py, artifacts))?; + if let Some(artifact_config) = self.artifact_config.as_ref().map(|c| c.as_ref(py)) { + dict.set_item("artifact_config", artifact_config)?; + } else { + dict.set_item("artifact_config", py.None())?; + } + dict.set_item("skill", self.skill.__dict__(py)?)?; + if let Some(enemy) = self.enemy.as_ref().map(|e| e.__dict__(py)).transpose()? { + dict.set_item("enemy", enemy)?; + } else { + dict.set_item("enemy", py.None())?; + } + Ok(dict.into()) + } } diff --git a/src/applications/input/skill.rs b/src/applications/input/skill.rs index acad3f6..9014d21 100644 --- a/src/applications/input/skill.rs +++ b/src/applications/input/skill.rs @@ -22,7 +22,10 @@ impl PySkillInterface { Ok(Self { index, config }) } pub fn __repr__(&self) -> PyResult { - Ok(format!("SkillInterface(index: {}, config: {:?})", self.index, self.config)) + Ok(format!( + "SkillInterface(index: {}, config: {:?})", + self.index, self.config + )) } #[getter] @@ -36,7 +39,6 @@ impl PySkillInterface { } Ok(dict.into()) } - } impl TryInto for PySkillInterface {