lsp_core/systems/
links.rsuse bevy_ecs::prelude::*;
use lsp_types::Url;
use tracing::instrument;
use crate::{prelude::*, util::ns::owl};
pub fn derive_prefix_links(
mut query: Query<(Entity, &Prefixes, Option<&mut DocumentLinks>), Changed<Prefixes>>,
mut commands: Commands,
) {
const SOURCE: &'static str = "prefix import";
for (e, turtle, mut links) in &mut query {
let new_links: Vec<_> = turtle.0.iter().map(|u| (u.url.clone(), SOURCE)).collect();
if let Some(links) = links.as_mut() {
links.retain(|e| e.1 != SOURCE);
}
match (new_links.is_empty(), links) {
(false, None) => {
commands.entity(e).insert(DocumentLinks(new_links));
}
(false, Some(mut links)) => {
links.extend(new_links);
}
_ => {}
}
}
}
#[instrument(skip(query, commands))]
pub fn derive_owl_imports_links(
mut query: Query<(Entity, &Triples, &Label, Option<&mut DocumentLinks>), Changed<Triples>>,
mut commands: Commands,
) {
const SOURCE: &'static str = "owl:imports";
for (e, triples, label, mut links) in &mut query {
if let Some(links) = links.as_mut() {
links.retain(|e| e.1 != SOURCE);
}
let new_links: Vec<_> = triples
.0
.iter()
.filter(|t| t.predicate.as_str() == owl::imports.iriref().as_str())
.flat_map(|t| Url::parse(t.object.as_str()))
.map(|obj| (obj, SOURCE))
.collect();
let link_display: Vec<_> = new_links.iter().map(|x| x.0.as_str()).collect();
tracing::info!("New linkess {} {:?}", label.as_str(), link_display);
if !new_links.is_empty() {
match links {
Some(mut links) => {
links.extend(new_links);
}
None => {
commands.entity(e).insert(DocumentLinks(new_links));
}
}
}
}
}