Skip to content

Commit

Permalink
Fix yaml serialization issues
Browse files Browse the repository at this point in the history
  • Loading branch information
maddymakesgames committed May 28, 2024
1 parent 23b1977 commit 45cbaea
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 6 deletions.
18 changes: 13 additions & 5 deletions lib/src/saves/ops/mods/auroras_additions.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
use std::collections::HashMap;

use anyhow::{anyhow, Result};
use saphyr::{Hash, Yaml};
use saphyr::{Hash, Yaml, YamlEmitter};

use crate::{
saves::{
mods::{auroras_additions::AurorasAdditionsSave, ModFile, ModSave},
ops::XML_VERSION_HEADER,
session::{RootSavedSession, SavedSession},
},
utils::ResultMapIter,
Expand Down Expand Up @@ -42,7 +43,7 @@ impl ModFile for AurorasAdditionsSave {

let session = quick_xml::de::from_str::<SavedSession>(session)?;

sessions_per_level.insert((sid.to_owned(), mode.to_owned()), session);
sessions_per_level.insert((sid.to_owned(), mode.trim().to_owned()), session);
}

let mut mod_sessions_per_level = HashMap::new();
Expand All @@ -61,7 +62,7 @@ impl ModFile for AurorasAdditionsSave {
"Aurora's Additions ModSessionsPerLevel entry has improperly formatted key"
))?;

mod_sessions_per_level.insert((sid.to_owned(), mode.to_owned()), value.clone());
mod_sessions_per_level.insert((sid.to_owned(), mode.trim().to_owned()), value.clone());
}

let mut mod_sessions_per_level_binary = HashMap::new();
Expand Down Expand Up @@ -100,7 +101,8 @@ impl ModFile for AurorasAdditionsSave {
mod_data.insert(mod_name.to_owned(), base64.to_owned());
}

mod_sessions_per_level_binary.insert((sid.to_owned(), mode.to_owned()), mod_data);
mod_sessions_per_level_binary
.insert((sid.to_owned(), mode.trim().to_owned()), mod_data);
}

let music_volume_memory = yaml["MusicVolumeMemory"]
Expand All @@ -124,7 +126,13 @@ impl ModFile for AurorasAdditionsSave {
.map(|(sid_mode, session)| {
Ok((
sid_mode,
quick_xml::se::to_string::<RootSavedSession>(&session.clone().into())?,
format!(
"{XML_VERSION_HEADER}{}",
quick_xml::se::to_string_with_root::<RootSavedSession>(
"Session",
&session.clone().into(),
)?
),
))
})
.map_result(|((sid, mode), session)| {
Expand Down
9 changes: 8 additions & 1 deletion lib/src/saves/ops/mods/collab_utils2.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ use std::collections::{HashMap, HashSet};
use crate::{
saves::{
mods::{collab_utils2::CollabsUtils2Save, ModFile, ModSave},
ops::XML_VERSION_HEADER,
session::{RootSavedSession, SavedSession},
util::FileTime,
},
Expand Down Expand Up @@ -183,7 +184,13 @@ impl ModFile for CollabsUtils2Save {
.map(|(sid, session)| {
Ok((
sid,
quick_xml::se::to_string::<RootSavedSession>(&session.clone().into())?,
format!(
"{XML_VERSION_HEADER}{}",
quick_xml::se::to_string_with_root::<RootSavedSession>(
"Session",
&session.clone().into()
)?
),
))
})
.map_result(|(sid, session)| (Yaml::String(sid.clone()), Yaml::String(session)))
Expand Down

0 comments on commit 45cbaea

Please sign in to comment.