Retrieve declarations using traits and not objects

This commit is contained in:
Patrick Lühne 2020-04-17 04:06:22 +02:00
parent 0e78e4ea57
commit 0d5971cad7
Signed by: patrick
GPG Key ID: 05F3611E97A70ABF
4 changed files with 185 additions and 124 deletions

View File

@ -9,23 +9,3 @@ pub(crate) use literals::{boolean, integer, special_integer, string};
pub(crate) use names::{function_or_predicate_name, variable_name}; pub(crate) use names::{function_or_predicate_name, variable_name};
pub use terms::term; pub use terms::term;
pub use formulas::formula; pub use formulas::formula;
pub struct Declarations
{
function_declarations: std::cell::RefCell<crate::FunctionDeclarations>,
predicate_declarations: std::cell::RefCell<crate::PredicateDeclarations>,
free_variable_declarations: std::cell::RefCell<crate::VariableDeclarations>,
}
impl Declarations
{
pub fn new() -> Self
{
Self
{
function_declarations: std::cell::RefCell::new(crate::FunctionDeclarations::new()),
predicate_declarations: std::cell::RefCell::new(crate::PredicateDeclarations::new()),
free_variable_declarations: std::cell::RefCell::new(vec![]),
}
}
}

View File

@ -9,10 +9,12 @@ use nom::
sequence::{delimited, pair, preceded, terminated, tuple}, sequence::{delimited, pair, preceded, terminated, tuple},
}; };
use super::{Declarations, boolean, word_boundary}; use super::{boolean, word_boundary};
pub fn predicate<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) pub fn predicate<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Predicate> -> IResult<&'i str, crate::Predicate>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
map map
( (
@ -25,34 +27,17 @@ pub fn predicate<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDec
None => vec![], None => vec![],
}; };
let mut predicate_declarations = d.predicate_declarations.borrow_mut(); let declaration = d.find_or_create_predicate_declaration(name, arguments.len());
let declaration = match predicate_declarations.iter()
.find(|x| x.name == name && x.arity == arguments.len())
{
Some(declaration) => std::rc::Rc::clone(&declaration),
None =>
{
let declaration = crate::PredicateDeclaration
{
name: name.to_string(),
arity: arguments.len(),
};
let declaration = std::rc::Rc::new(declaration);
predicate_declarations.insert(std::rc::Rc::clone(&declaration));
declaration
},
};
crate::Predicate::new(declaration, arguments) crate::Predicate::new(declaration, arguments)
}, },
)(i) )(i)
} }
fn not<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) fn not<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
map map
( (
@ -69,8 +54,10 @@ fn not<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationSt
)(i) )(i)
} }
fn and<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) fn and<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formulas> -> IResult<&'i str, crate::Formulas>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
map_res map_res
( (
@ -102,8 +89,10 @@ fn and<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationSt
)(i) )(i)
} }
fn or<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) fn or<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formulas> -> IResult<&'i str, crate::Formulas>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
map_res map_res
( (
@ -135,9 +124,10 @@ fn or<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationSta
)(i) )(i)
} }
fn implies_left_to_right<'i, 'v>(i: &'i str, d: &Declarations, fn implies_left_to_right<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
map map
( (
@ -165,9 +155,10 @@ fn implies_left_to_right<'i, 'v>(i: &'i str, d: &Declarations,
)(i) )(i)
} }
fn implies_right_to_left<'i, 'v>(i: &'i str, d: &Declarations, fn implies_right_to_left<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
map map
( (
@ -195,8 +186,10 @@ fn implies_right_to_left<'i, 'v>(i: &'i str, d: &Declarations,
)(i) )(i)
} }
fn if_and_only_if<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) fn if_and_only_if<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formulas> -> IResult<&'i str, crate::Formulas>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
map_res map_res
( (
@ -224,9 +217,11 @@ fn if_and_only_if<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDe
)(i) )(i)
} }
fn quantified_formula<'i, 'b, 'v>(i: &'i str, d: &Declarations, fn quantified_formula<'i, 'b, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer,
v: &'v crate::VariableDeclarationStackLayer, keyword: &'b str) keyword: &'b str)
-> IResult<&'i str, crate::QuantifiedFormula> -> IResult<&'i str, crate::QuantifiedFormula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
preceded preceded
( (
@ -280,8 +275,10 @@ fn quantified_formula<'i, 'b, 'v>(i: &'i str, d: &Declarations,
)(i) )(i)
} }
fn compare<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) fn compare<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Compare> -> IResult<&'i str, crate::Compare>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
map map
( (
@ -335,21 +332,26 @@ fn compare<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarati
)(i) )(i)
} }
fn exists<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) fn exists<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::QuantifiedFormula> -> IResult<&'i str, crate::QuantifiedFormula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
quantified_formula(i, d, v, "exists") quantified_formula(i, d, v, "exists")
} }
fn for_all<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) fn for_all<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::QuantifiedFormula> -> IResult<&'i str, crate::QuantifiedFormula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
quantified_formula(i, d, v, "forall") quantified_formula(i, d, v, "forall")
} }
fn formula_parenthesized<'i, 'v>(i: &'i str, d: &Declarations, fn formula_parenthesized<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
delimited delimited
( (
@ -367,9 +369,10 @@ fn formula_parenthesized<'i, 'v>(i: &'i str, d: &Declarations,
)(i) )(i)
} }
fn formula_precedence_0<'i, 'v>(i: &'i str, d: &Declarations, fn formula_precedence_0<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -392,9 +395,10 @@ fn formula_precedence_0<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
fn formula_precedence_1<'i, 'v>(i: &'i str, d: &Declarations, fn formula_precedence_1<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -412,9 +416,10 @@ fn formula_precedence_1<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
fn formula_precedence_2<'i, 'v>(i: &'i str, d: &Declarations, fn formula_precedence_2<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -423,9 +428,10 @@ fn formula_precedence_2<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
fn formula_precedence_3<'i, 'v>(i: &'i str, d: &Declarations, fn formula_precedence_3<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -438,9 +444,10 @@ fn formula_precedence_3<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
fn formula_precedence_4<'i, 'v>(i: &'i str, d: &Declarations, fn formula_precedence_4<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -453,9 +460,10 @@ fn formula_precedence_4<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
fn formula_precedence_5<'i, 'v>(i: &'i str, d: &Declarations, fn formula_precedence_5<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -465,9 +473,10 @@ fn formula_precedence_5<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
fn formula_precedence_6<'i, 'v>(i: &'i str, d: &Declarations, fn formula_precedence_6<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -480,8 +489,10 @@ fn formula_precedence_6<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
pub fn formula<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) pub fn formula<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Formula> -> IResult<&'i str, crate::Formula>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
formula_precedence_6(i, d, v) formula_precedence_6(i, d, v)
} }
@ -489,9 +500,9 @@ pub fn formula<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDecla
#[cfg(test)] #[cfg(test)]
mod tests mod tests
{ {
use crate::parse::formulas::*;
use crate::parse::formulas as original;
use crate::{Formula, ImplicationDirection, Term, VariableDeclarationStackLayer}; use crate::{Formula, ImplicationDirection, Term, VariableDeclarationStackLayer};
use crate::parse::formulas as original;
use crate::utils::*;
fn formula(i: &str) -> Formula fn formula(i: &str) -> Formula
{ {

View File

@ -9,11 +9,12 @@ use nom::
sequence::{delimited, pair, preceded, terminated}, sequence::{delimited, pair, preceded, terminated},
}; };
use super::{Declarations, boolean, function_or_predicate_name, integer, special_integer, string, use super::{boolean, function_or_predicate_name, integer, special_integer, string, variable_name};
variable_name};
fn negative<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) fn negative<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Term> -> IResult<&'i str, crate::Term>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
map map
( (
@ -37,8 +38,10 @@ fn negative<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarat
)(i) )(i)
} }
fn absolute_value<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) fn absolute_value<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Term> -> IResult<&'i str, crate::Term>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
map map
( (
@ -60,9 +63,11 @@ fn absolute_value<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDe
)(i) )(i)
} }
pub(crate) fn function_or_predicate<'i, 'v>(i: &'i str, d: &Declarations, pub(crate) fn function_or_predicate<'i, 'v, D>(i: &'i str, d: &D,
v: &'v crate::VariableDeclarationStackLayer) v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, (&'i str, Option<crate::Terms>)> -> IResult<&'i str, (&'i str, Option<crate::Terms>)>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
pair pair
( (
@ -97,8 +102,10 @@ pub(crate) fn function_or_predicate<'i, 'v>(i: &'i str, d: &Declarations,
)(i) )(i)
} }
fn function<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) fn function<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Function> -> IResult<&'i str, crate::Function>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
map map
( (
@ -111,26 +118,7 @@ fn function<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarat
None => vec![], None => vec![],
}; };
let mut function_declarations = d.function_declarations.borrow_mut(); let declaration = d.find_or_create_function_declaration(name, arguments.len());
let declaration = match function_declarations.iter()
.find(|x| x.name == name && x.arity == arguments.len())
{
Some(declaration) => std::rc::Rc::clone(&declaration),
None =>
{
let declaration = crate::FunctionDeclaration
{
name: name.to_string(),
arity: arguments.len(),
};
let declaration = std::rc::Rc::new(declaration);
function_declarations.insert(std::rc::Rc::clone(&declaration));
declaration
},
};
crate::Function::new(declaration, arguments) crate::Function::new(declaration, arguments)
}, },
@ -161,9 +149,10 @@ fn variable<'i, 'v>(i: &'i str, v: &'v crate::VariableDeclarationStackLayer)
)(i) )(i)
} }
fn term_parenthesized<'i, 'v>(i: &'i str, d: &Declarations, fn term_parenthesized<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Term> -> IResult<&'i str, crate::Term>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
delimited delimited
( (
@ -181,9 +170,10 @@ fn term_parenthesized<'i, 'v>(i: &'i str, d: &Declarations,
)(i) )(i)
} }
fn term_precedence_0<'i, 'v>(i: &'i str, d: &Declarations, fn term_precedence_0<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Term> -> IResult<&'i str, crate::Term>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -222,9 +212,10 @@ fn term_precedence_0<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
fn term_precedence_1<'i, 'v>(i: &'i str, d: &Declarations, fn term_precedence_1<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Term> -> IResult<&'i str, crate::Term>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -233,9 +224,10 @@ fn term_precedence_1<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
fn term_precedence_2<'i, 'v>(i: &'i str, d: &Declarations, fn term_precedence_2<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Term> -> IResult<&'i str, crate::Term>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -266,9 +258,10 @@ fn term_precedence_2<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
fn term_precedence_3<'i, 'v>(i: &'i str, d: &Declarations, fn term_precedence_3<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Term> -> IResult<&'i str, crate::Term>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -311,8 +304,10 @@ fn term_precedence_3<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
fn term_precedence_4<'i, 'v>(i: &'i str, d: &Declarations, fn term_precedence_4<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
v: &'v crate::VariableDeclarationStackLayer) -> IResult<&'i str, crate::Term> -> IResult<&'i str, crate::Term>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
alt alt
(( ((
@ -353,8 +348,10 @@ fn term_precedence_4<'i, 'v>(i: &'i str, d: &Declarations,
))(i) ))(i)
} }
pub fn term<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarationStackLayer) pub fn term<'i, 'v, D>(i: &'i str, d: &D, v: &'v crate::VariableDeclarationStackLayer)
-> IResult<&'i str, crate::Term> -> IResult<&'i str, crate::Term>
where
D: crate::FindOrCreateFunctionDeclaration + crate::FindOrCreatePredicateDeclaration
{ {
term_precedence_4(i, d, v) term_precedence_4(i, d, v)
} }
@ -362,9 +359,9 @@ pub fn term<'i, 'v>(i: &'i str, d: &Declarations, v: &'v crate::VariableDeclarat
#[cfg(test)] #[cfg(test)]
mod tests mod tests
{ {
use crate::parse::terms::*;
use crate::parse::terms as original;
use crate::{Term, VariableDeclaration, VariableDeclarationStackLayer}; use crate::{Term, VariableDeclaration, VariableDeclarationStackLayer};
use crate::parse::terms as original;
use crate::utils::*;
fn term(i: &str) -> Term fn term(i: &str) -> Term
{ {

View File

@ -1,20 +1,15 @@
pub trait FindFunctionDeclaration pub trait FindOrCreateFunctionDeclaration
{ {
fn find_function_declaration(&self, name: &str, arity: usize) fn find_or_create_function_declaration(&self, name: &str, arity: usize)
-> std::rc::Rc<crate::FunctionDeclaration>; -> std::rc::Rc<crate::FunctionDeclaration>;
} }
pub trait FindPredicateDeclaration pub trait FindOrCreatePredicateDeclaration
{ {
fn find_predicate_declaration(&self, name: &str, arity: usize) fn find_or_create_predicate_declaration(&self, name: &str, arity: usize)
-> std::rc::Rc<crate::PredicateDeclaration>; -> std::rc::Rc<crate::PredicateDeclaration>;
} }
pub trait FindVariableDeclaration
{
fn find_variable_declaration(&self, name: &str) -> std::rc::Rc<crate::VariableDeclaration>;
}
pub struct BoundVariableDeclarations<'p> pub struct BoundVariableDeclarations<'p>
{ {
parent: &'p VariableDeclarationStackLayer<'p>, parent: &'p VariableDeclarationStackLayer<'p>,
@ -144,3 +139,81 @@ impl<'p> VariableDeclarationStackLayer<'p>
} }
} }
} }
#[cfg(test)]
pub struct Declarations
{
function_declarations: std::cell::RefCell<crate::FunctionDeclarations>,
predicate_declarations: std::cell::RefCell<crate::PredicateDeclarations>,
//free_variable_declarations: std::cell::RefCell<crate::VariableDeclarations>,
}
#[cfg(test)]
impl Declarations
{
pub fn new() -> Self
{
Self
{
function_declarations: std::cell::RefCell::new(crate::FunctionDeclarations::new()),
predicate_declarations: std::cell::RefCell::new(crate::PredicateDeclarations::new()),
//free_variable_declarations: std::cell::RefCell::new(vec![]),
}
}
}
#[cfg(test)]
impl FindOrCreateFunctionDeclaration for Declarations
{
fn find_or_create_function_declaration(&self, name: &str, arity: usize)
-> std::rc::Rc<crate::FunctionDeclaration>
{
let mut function_declarations = self.function_declarations.borrow_mut();
match function_declarations.iter().find(|x| x.name == name && x.arity == arity)
{
Some(declaration) => std::rc::Rc::clone(&declaration),
None =>
{
let declaration = crate::FunctionDeclaration
{
name: name.to_string(),
arity,
};
let declaration = std::rc::Rc::new(declaration);
function_declarations.insert(std::rc::Rc::clone(&declaration));
declaration
},
}
}
}
#[cfg(test)]
impl FindOrCreatePredicateDeclaration for Declarations
{
fn find_or_create_predicate_declaration(&self, name: &str, arity: usize)
-> std::rc::Rc<crate::PredicateDeclaration>
{
let mut predicate_declarations = self.predicate_declarations.borrow_mut();
match predicate_declarations.iter().find(|x| x.name == name && x.arity == arity)
{
Some(declaration) => std::rc::Rc::clone(&declaration),
None =>
{
let declaration = crate::PredicateDeclaration
{
name: name.to_string(),
arity,
};
let declaration = std::rc::Rc::new(declaration);
predicate_declarations.insert(std::rc::Rc::clone(&declaration));
declaration
},
}
}
}