Skip to content

Commit

Permalink
Remove component for all IRIs from IRIMappedIndex
Browse files Browse the repository at this point in the history
  • Loading branch information
b-gehrke committed Nov 19, 2024
1 parent fc4aaca commit bca389b
Showing 1 changed file with 36 additions and 18 deletions.
54 changes: 36 additions & 18 deletions src/ontology/iri_mapped.rs
Original file line number Diff line number Diff line change
Expand Up @@ -199,25 +199,17 @@ impl<A: ForIRI, AA: ForIndex<A>> OntologyIndex<A, AA> for IRIMappedIndex<A, AA>
}

fn index_take(&mut self, cmp: &AnnotatedComponent<A>) -> Option<AnnotatedComponent<A>> {
let iris = self.aa_to_iris(cmp);
if !iris.is_empty() {
let iri = iris.iter().next();
if let Some(iri) = iri {
self.mut_set_for_iri(iri).take(cmp).map(|aax| aax.unwrap())
} else {
None
}
} else {
None
}
self.aa_to_iris(cmp).iter().fold(None, |val, iri| {
self.mut_set_for_iri(iri)
.take(cmp)
.map_or(val, |c| Some(c.unwrap()))
})
}

fn index_remove(&mut self, cmp: &AnnotatedComponent<A>) -> bool {
if let Some(iri) = self.aa_to_iris(cmp).iter().next() {
self.mut_set_for_iri(&iri.clone()).remove(cmp)
} else {
false
}
self.aa_to_iris(cmp).iter().fold(false, |val, iri| {
self.mut_set_for_iri(iri).remove(cmp) || val
})
}
}

Expand Down Expand Up @@ -332,8 +324,8 @@ impl<A: ForIRI, AA: ForIndex<A>> From<IRIMappedOntology<A, AA>> for SetOntology<

#[cfg(test)]
mod test {
use super::IRIMappedOntology;
use crate::model::*;
use super::{IRIMappedIndex, IRIMappedOntology};
use crate::{model::*, ontology::indexed::OntologyIndex};

#[test]
fn test_ontology_cons() {
Expand Down Expand Up @@ -433,4 +425,30 @@ mod test {
]
);
}

#[test]
fn test_index_remove() {
let build = Build::new();
let mut i = IRIMappedIndex::<RcStr, RcAnnotatedComponent>::new();
let disj1 = AnnotatedComponent {
component: Component::DisjointClasses(DisjointClasses(vec![
ClassExpression::Class(build.class("http://www.example.com/#A")),
ClassExpression::Class(build.class("http://www.example.com/#B")),
])),
ann: Default::default(),
};

i.index_insert(RcAnnotatedComponent::new(disj1.clone()));
i.index_remove(&disj1);

let irindex = i.irindex.borrow();

let mut v: Vec<_> = irindex
.iter()
.flat_map(|(i, s)| s.into_iter().map(move |c| (i.clone(), c.clone())))
.collect();
v.sort();

assert_eq!(v, Vec::<(IRI<RcStr>, RcAnnotatedComponent)>::new())
}
}

0 comments on commit bca389b

Please sign in to comment.