improve diff

This commit is contained in:
Dull Bananas 2024-05-19 05:19:07 +00:00
parent 06b01ffecf
commit 7977ee166a

View File

@ -100,16 +100,25 @@ pub fn check_dump_diff(conn: &mut PgConnection, mut before: String, name: &str)
if only_in_before.is_empty() && only_in_after.is_empty() { if only_in_before.is_empty() && only_in_after.is_empty() {
return; return;
} }
// add empty strings to the shorter vec so the lengths match let after_has_more =
if only_in_before.len() < only_in_after.len() { only_in_before.len() < only_in_after.len();
only_in_before.resize_with(only_in_after.len(), Default::default); // outer iterator in the loop below should be the one with empty strings, otherwise the empty strings
// would appear to have the most similarity
let (chunks_gt, chunks_lt) = if after_has_more
{
only_in_before.resize_with(only_in_after.len(),Default::default);
(&mut only_in_after, &only_in_before)
} else { } else {
only_in_after.resize_with(only_in_before.len(), Default::default); only_in_after.resize_with(only_in_before.len(),Default::default);
} (&mut only_in_before, &only_in_after)
};
let mut output = format!("These changes need to be applied in {name}:"); let mut output = format!("These changes need to be applied in {name}:");
for (before_chunk, before_chunk_filtered) in only_in_before { // todo rename variables
let (most_similar_chunk_index, (most_similar_chunk, _)) = only_in_after for (before_chunk, before_chunk_filtered) in chunks_lt {
let default = Default::default();
//panic!("{:?}",(before_chunk.clone(),chunks_lt.clone()));
let (most_similar_chunk_index, (most_similar_chunk, _)) = chunks_gt
.iter() .iter()
.enumerate() .enumerate()
.max_by_key(|(_, (after_chunk, after_chunk_filtered))| { .max_by_key(|(_, (after_chunk, after_chunk_filtered))| {
@ -120,10 +129,13 @@ pub fn check_dump_diff(conn: &mut PgConnection, mut before: String, name: &str)
if c.is_lowercase())) if c.is_lowercase()))
.count() .count()
}) })
.expect("resize should have prevented this from failing"); .unwrap_or((0,&default));
output.push('\n'); output.push('\n');
for line in diff::lines(most_similar_chunk, &before_chunk) { let lines = if !after_has_more{diff::lines(&before_chunk,most_similar_chunk)}else{
diff::lines(most_similar_chunk, &before_chunk)};
for line in lines
{
match line { match line {
diff::Result::Left(s) => write!(&mut output, "\n- {s}"), diff::Result::Left(s) => write!(&mut output, "\n- {s}"),
diff::Result::Right(s) => write!(&mut output, "\n+ {s}"), diff::Result::Right(s) => write!(&mut output, "\n+ {s}"),
@ -131,10 +143,11 @@ pub fn check_dump_diff(conn: &mut PgConnection, mut before: String, name: &str)
} }
.expect("failed to build string"); .expect("failed to build string");
} }
only_in_after.swap_remove(most_similar_chunk_index); if !chunks_gt.is_empty() {
chunks_gt.swap_remove(most_similar_chunk_index);}
} }
// should have all been removed // should have all been removed
assert_eq!(only_in_after.len(), 0); assert_eq!(chunks_gt.len(), 0);
panic!("{output}"); panic!("{output}");
} }