use crate::prelude::*;
impl Runtime {
pub fn get_prop_definition_by_name(&self, predicate_name: &str) -> Option<&DefPropStmt> {
let parts = predicate_name.split(MOD_SIGN).collect::<Vec<&str>>();
if parts.len() != 1 {
unimplemented!();
}
for environment in self.iter_environments_from_top() {
if let Some(definition) = environment.defined_def_props.get(predicate_name) {
return Some(definition);
}
}
None
}
pub fn get_abstract_prop_definition_by_name(
&self,
predicate_name: &str,
) -> Option<&DefAbstractPropStmt> {
let parts = predicate_name.split(MOD_SIGN).collect::<Vec<&str>>();
if parts.len() != 1 {
unimplemented!();
}
for environment in self.iter_environments_from_top() {
if let Some(definition) = environment.defined_abstract_props.get(predicate_name) {
return Some(definition);
}
}
None
}
pub fn get_algo_definition_by_name(&self, algo_name: &str) -> Option<&DefAlgoStmt> {
for environment in self.iter_environments_from_top() {
if let Some(definition) = environment.defined_algorithms.get(algo_name) {
return Some(definition);
}
}
None
}
pub fn get_family_definition_by_name(&self, family_name: &str) -> Option<&DefFamilyStmt> {
let parts = family_name.split(MOD_SIGN).collect::<Vec<&str>>();
if parts.len() != 1 {
unimplemented!();
}
for environment in self.iter_environments_from_top() {
if let Some(definition) = environment.defined_families.get(family_name) {
return Some(definition);
}
}
None
}
pub fn get_cloned_family_definition_by_name(&self, family_name: &str) -> Option<DefFamilyStmt> {
let parts = family_name.split(MOD_SIGN).collect::<Vec<&str>>();
if parts.len() != 1 {
unimplemented!();
}
for environment in self.iter_environments_from_top() {
if let Some(definition) = environment.defined_families.get(family_name) {
return Some(definition.clone());
}
}
None
}
}