2020-02-04 23:33:59 +01:00
|
|
|
mod arithmetic_terms;
|
2020-02-05 02:29:38 +01:00
|
|
|
mod variable_declaration_stack;
|
2020-02-04 23:33:59 +01:00
|
|
|
|
|
|
|
pub(crate) use arithmetic_terms::*;
|
2020-02-05 02:29:38 +01:00
|
|
|
pub(crate) use variable_declaration_stack::*;
|
2020-02-04 23:33:59 +01:00
|
|
|
|
|
|
|
#[derive(Clone, Copy, Debug, Eq, Ord, PartialEq, PartialOrd)]
|
|
|
|
pub(crate) enum OperatorNotation
|
|
|
|
{
|
|
|
|
Prefix,
|
|
|
|
Infix,
|
|
|
|
}
|
|
|
|
|
2020-02-05 19:40:21 +01:00
|
|
|
#[derive(Clone, Copy, Eq, Ord, PartialEq, PartialOrd)]
|
|
|
|
pub enum Domain
|
2020-02-04 16:42:50 +01:00
|
|
|
{
|
|
|
|
Program,
|
|
|
|
Integer,
|
|
|
|
}
|
|
|
|
|
2020-02-05 19:40:21 +01:00
|
|
|
impl std::fmt::Debug for Domain
|
|
|
|
{
|
|
|
|
fn fmt(&self, formatter: &mut std::fmt::Formatter) -> std::fmt::Result
|
|
|
|
{
|
|
|
|
match self
|
|
|
|
{
|
|
|
|
Domain::Program => write!(formatter, "program"),
|
|
|
|
Domain::Integer => write!(formatter, "integer"),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl std::fmt::Display for Domain
|
|
|
|
{
|
|
|
|
fn fmt(&self, formatter: &mut std::fmt::Formatter) -> std::fmt::Result
|
|
|
|
{
|
|
|
|
write!(formatter, "{:?}", self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-04 16:42:50 +01:00
|
|
|
pub(crate) struct ScopedFormula
|
|
|
|
{
|
|
|
|
pub free_variable_declarations: std::rc::Rc<foliage::VariableDeclarations>,
|
|
|
|
pub formula: Box<foliage::Formula>,
|
|
|
|
}
|
2020-02-05 01:10:33 +01:00
|
|
|
|
2020-02-05 19:40:21 +01:00
|
|
|
pub type InputConstantDeclarationDomains
|
|
|
|
= std::collections::BTreeMap<std::rc::Rc<foliage::FunctionDeclaration>, Domain>;
|
|
|
|
|
2020-02-05 01:10:33 +01:00
|
|
|
pub fn parse_predicate_declaration(input: &str)
|
|
|
|
-> Result<std::rc::Rc<foliage::PredicateDeclaration>, crate::Error>
|
|
|
|
{
|
|
|
|
let mut parts = input.split("/");
|
|
|
|
|
|
|
|
let name = match parts.next()
|
|
|
|
{
|
|
|
|
Some(name) => name.to_string(),
|
|
|
|
None => return Err(crate::Error::new_parse_predicate_declaration()),
|
|
|
|
};
|
|
|
|
|
|
|
|
use std::str::FromStr;
|
|
|
|
|
|
|
|
let arity = match parts.next()
|
|
|
|
{
|
|
|
|
Some(arity)
|
|
|
|
=> usize::from_str(arity).map_err(|_| crate::Error::new_parse_predicate_declaration())?,
|
|
|
|
None => return Err(crate::Error::new_parse_predicate_declaration()),
|
|
|
|
};
|
|
|
|
|
|
|
|
if parts.next().is_some()
|
|
|
|
{
|
|
|
|
return Err(crate::Error::new_parse_predicate_declaration());
|
|
|
|
}
|
|
|
|
|
|
|
|
Ok(std::rc::Rc::new(foliage::PredicateDeclaration
|
|
|
|
{
|
|
|
|
name,
|
|
|
|
arity,
|
|
|
|
}))
|
|
|
|
}
|
2020-02-05 19:40:21 +01:00
|
|
|
|
|
|
|
pub fn parse_constant_declaration(input: &str)
|
|
|
|
-> Result<(std::rc::Rc<foliage::FunctionDeclaration>, crate::Domain), crate::Error>
|
|
|
|
{
|
|
|
|
let mut parts = input.split(":");
|
|
|
|
|
|
|
|
let name = parts.next().ok_or(crate::Error::new_parse_constant_declaration())?.trim();
|
|
|
|
|
|
|
|
let domain = match parts.next()
|
|
|
|
{
|
|
|
|
None => crate::Domain::Program,
|
|
|
|
Some(value) => match value.trim()
|
|
|
|
{
|
|
|
|
"program" => crate::Domain::Program,
|
|
|
|
"integer" => crate::Domain::Integer,
|
|
|
|
_ => return Err(crate::Error::new_parse_constant_declaration()),
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
if parts.next().is_some()
|
|
|
|
{
|
|
|
|
return Err(crate::Error::new_parse_constant_declaration());
|
|
|
|
}
|
|
|
|
|
|
|
|
let constant_declaration = std::rc::Rc::new(foliage::FunctionDeclaration
|
|
|
|
{
|
|
|
|
name: name.to_string(),
|
|
|
|
arity: 0,
|
|
|
|
});
|
|
|
|
|
|
|
|
Ok((constant_declaration, domain))
|
|
|
|
}
|