Remove unneeded indirection from vector types

The type aliases for vectors of formulas and terms were defined as
vectors of boxed formulas and terms, respectively. This is an
unnecessary indirection, so store the formulas and terms directly.
This commit is contained in:
Patrick Lühne 2020-04-13 22:16:01 +02:00
parent 2fa592576b
commit 8e32b58c99
Signed by: patrick
GPG Key ID: 05F3611E97A70ABF

View File

@ -165,12 +165,12 @@ impl BinaryOperation
pub struct Function pub struct Function
{ {
pub declaration: std::rc::Rc<FunctionDeclaration>, pub declaration: std::rc::Rc<FunctionDeclaration>,
pub arguments: Vec<Box<Term>>, pub arguments: Terms,
} }
impl Function impl Function
{ {
pub fn new(declaration: std::rc::Rc<FunctionDeclaration>, arguments: Vec<Box<Term>>) -> Self pub fn new(declaration: std::rc::Rc<FunctionDeclaration>, arguments: Terms) -> Self
{ {
assert_eq!(declaration.arity, arguments.len(), assert_eq!(declaration.arity, arguments.len(),
"function has a different number of arguments then declared"); "function has a different number of arguments then declared");
@ -288,12 +288,12 @@ impl Implies
pub struct Predicate pub struct Predicate
{ {
pub declaration: std::rc::Rc<PredicateDeclaration>, pub declaration: std::rc::Rc<PredicateDeclaration>,
pub arguments: Vec<Box<Term>>, pub arguments: Terms,
} }
impl Predicate impl Predicate
{ {
pub fn new(declaration: std::rc::Rc<PredicateDeclaration>, arguments: Vec<Box<Term>>) -> Self pub fn new(declaration: std::rc::Rc<PredicateDeclaration>, arguments: Terms) -> Self
{ {
assert_eq!(declaration.arity, arguments.len(), assert_eq!(declaration.arity, arguments.len(),
"predicate has a different number of arguments then declared"); "predicate has a different number of arguments then declared");
@ -320,7 +320,7 @@ pub enum Term
Variable(Variable), Variable(Variable),
} }
pub type Terms = Vec<Box<Term>>; pub type Terms = Vec<Term>;
impl Term impl Term
{ {
@ -359,8 +359,7 @@ impl Term
Self::boolean(false) Self::boolean(false)
} }
pub fn function(declaration: std::rc::Rc<FunctionDeclaration>, arguments: Vec<Box<Term>>) pub fn function(declaration: std::rc::Rc<FunctionDeclaration>, arguments: Terms) -> Self
-> Self
{ {
Self::Function(Function::new(declaration, arguments)) Self::Function(Function::new(declaration, arguments))
} }
@ -440,7 +439,7 @@ pub enum Formula
Predicate(Predicate), Predicate(Predicate),
} }
pub type Formulas = Vec<Box<Formula>>; pub type Formulas = Vec<Formula>;
impl Formula impl Formula
{ {
@ -533,8 +532,7 @@ impl Formula
Self::Or(arguments) Self::Or(arguments)
} }
pub fn predicate(declaration: std::rc::Rc<PredicateDeclaration>, arguments: Vec<Box<Term>>) pub fn predicate(declaration: std::rc::Rc<PredicateDeclaration>, arguments: Terms) -> Self
-> Self
{ {
Self::Predicate(Predicate::new(declaration, arguments)) Self::Predicate(Predicate::new(declaration, arguments))
} }