use super::super::Dag;
use super::IdStaticSet;
use super::Set;
use crate::IdSet;
#[derive(Copy, Clone)]
pub struct LegacyCodeNeedIdAccess;
impl<'a> From<(LegacyCodeNeedIdAccess, &'a IdStaticSet)> for IdSet {
fn from(value: (LegacyCodeNeedIdAccess, &'a IdStaticSet)) -> IdSet {
let set = value.1;
set.id_set_losing_order().clone()
}
}
impl<'a> From<(LegacyCodeNeedIdAccess, IdSet, &'a Dag)> for Set {
fn from(value: (LegacyCodeNeedIdAccess, IdSet, &'a Dag)) -> Set {
Set::from_id_set_dag(value.1, value.2).unwrap()
}
}
#[cfg(test)]
mod tests {
use nonblocking::non_blocking_result as r;
use super::super::id_static::tests::with_dag;
use super::*;
use crate::tests::dbg;
use crate::DagAlgorithm;
use crate::Result;
#[test]
fn test_legacy_convert() -> Result<()> {
use LegacyCodeNeedIdAccess as L;
with_dag(|dag| -> Result<()> {
let set1 = r(dag.ancestors("G".into()))?;
let spans: IdSet = (L, set1.as_any().downcast_ref::<IdStaticSet>().unwrap()).into();
let set2: Set = (L, spans.clone(), dag).into();
assert_eq!(dbg(&set1), "<spans [E:G+4:6, A:B+0:1]>");
assert_eq!(dbg(&set2), "<spans [E:G+4:6, A:B+0:1]>");
assert_eq!(dbg(&spans), "0 1 4 5 6");
Ok(())
})
}
}