[[package]]
name = "prolog_parser"
-version = "0.7.19"
+version = "0.7.20"
source = "registry+https://github.com/rust-lang/crates.io-index"
dependencies = [
"num 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)",
"downcast 0.9.1 (registry+https://github.com/rust-lang/crates.io-index)",
"num 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)",
"ordered-float 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)",
- "prolog_parser 0.7.19 (registry+https://github.com/rust-lang/crates.io-index)",
+ "prolog_parser 0.7.20 (registry+https://github.com/rust-lang/crates.io-index)",
"termion 1.5.1 (registry+https://github.com/rust-lang/crates.io-index)",
]
"checksum num-traits 0.1.41 (registry+https://github.com/rust-lang/crates.io-index)" = "cacfcab5eb48250ee7d0c7896b51a2c5eec99c1feea5f32025635f5ae4b00070"
"checksum num-traits 0.2.5 (registry+https://github.com/rust-lang/crates.io-index)" = "630de1ef5cc79d0cdd78b7e33b81f083cbfe90de0f4b2b2f07f905867c70e9fe"
"checksum ordered-float 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)" = "58d25b6c0e47b20d05226d288ff434940296e7e2f8b877975da32f862152241f"
-"checksum prolog_parser 0.7.19 (registry+https://github.com/rust-lang/crates.io-index)" = "121df281a26fc692c1b8089bfdc0ba010a4af06379dec213446297c0c357713a"
+"checksum prolog_parser 0.7.20 (registry+https://github.com/rust-lang/crates.io-index)" = "68e88532e8eb09eb4606d47a53e0849643292bc253f14cb80b348f13591a050e"
"checksum redox_syscall 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)" = "ab105df655884ede59d45b7070c8a65002d921461ee813a024558ca16030eea0"
"checksum redox_termios 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "7e891cfe48e9100a70a3b6eb652fef28920c117d366339687bd5576160db0f76"
"checksum termion 1.5.1 (registry+https://github.com/rust-lang/crates.io-index)" = "689a3bdfaab439fd92bc87df5c4c78417d3cbe537487274e9b0b2dce76e92096"
downcast = "0.9.1"
num = "0.2"
ordered-float = "0.5.0"
-prolog_parser = "0.7.19"
+prolog_parser = "0.7.20"
[dependencies.termion]
version = "1.4.0"
\ No newline at end of file
#[derive(Clone)]
pub enum TokenOrRedirect {
Atom(ClauseName),
- Op(ClauseName, Fixity),
+ Op(ClauseName, (usize, Specifier)),
NumberedVar(String),
CompositeRedirect(DirectedOp),
Redirect,
}
}
- fn enqueue_op(&mut self, ct: ClauseType, fixity: Fixity) {
- match fixity {
- Fixity::Post => {
- self.state_stack.push(TokenOrRedirect::Op(ct.name(), fixity));
- self.state_stack.push(TokenOrRedirect::CompositeRedirect(DirectedOp::Right(ct.name())));
- },
- Fixity::Pre => {
- let left_directed_op = DirectedOp::Left(ct.name(), false);
-
- self.state_stack.push(TokenOrRedirect::CompositeRedirect(left_directed_op));
- self.state_stack.push(TokenOrRedirect::Op(ct.name(), fixity));
- },
- Fixity::In => {
- let left_directed_op = DirectedOp::Left(ct.name(), true);
-
- self.state_stack.push(TokenOrRedirect::CompositeRedirect(left_directed_op));
- self.state_stack.push(TokenOrRedirect::Op(ct.name(), fixity));
- self.state_stack.push(TokenOrRedirect::CompositeRedirect(DirectedOp::Right(ct.name())));
- }
+ fn enqueue_op(&mut self, ct: ClauseType, spec: (usize, Specifier)) {
+ if is_postfix!(spec.1) {
+ self.state_stack.push(TokenOrRedirect::Op(ct.name(), spec));
+ self.state_stack.push(TokenOrRedirect::CompositeRedirect(DirectedOp::Right(ct.name())));
+ } else if is_prefix!(spec.1) {
+ let left_directed_op = DirectedOp::Left(ct.name(), false);
+
+ self.state_stack.push(TokenOrRedirect::CompositeRedirect(left_directed_op));
+ self.state_stack.push(TokenOrRedirect::Op(ct.name(), spec));
+ } else { // if is_infix!(spec.1)
+ let left_directed_op = DirectedOp::Left(ct.name(), true);
+
+ self.state_stack.push(TokenOrRedirect::CompositeRedirect(left_directed_op));
+ self.state_stack.push(TokenOrRedirect::Op(ct.name(), spec));
+ self.state_stack.push(TokenOrRedirect::CompositeRedirect(DirectedOp::Right(ct.name())));
}
}
fn format_clause(&mut self, iter: &mut HCPreOrderIterator, arity: usize, ct: ClauseType)
{
- if let Some(fixity) = ct.fixity() {
+ if let Some(spec) = ct.spec() {
if !self.ignore_ops {
- return self.enqueue_op(ct, fixity);
+ return self.enqueue_op(ct, spec);
}
} else if self.numbervars && is_numbered_var(&ct, arity) {
let addr = iter.stack().last().cloned().unwrap();
})
}
- fn print_atom(&mut self, atom: &ClauseName, fixity: Option<Fixity>) {
+ fn print_atom(&mut self, atom: &ClauseName, spec: Option<(usize, Specifier)>) {
match atom.as_str() {
"" => self.outputter.append("''"),
";" | "!" => self.outputter.append(atom.as_str()),
- s => if fixity.is_some() || !self.quoted || non_quoted_token(s.chars()) {
+ s => if spec.is_some() || !self.quoted || non_quoted_token(s.chars()) {
self.outputter.append(atom.as_str())
} else {
if self.quoted {
fn print_constant(&mut self, c: Constant, op: &Option<DirectedOp>) {
match c {
- Constant::Atom(ref atom, Some(fixity)) => {
+ Constant::Atom(ref atom, Some(spec)) => {
if let Some(ref op) = op {
if self.outputter.ends_with(&format!(" {}", op.as_str())) {
self.outputter.push_char(' ');
self.outputter.push_char('(');
}
- self.print_atom(atom, Some(fixity));
+ self.print_atom(atom, Some(spec));
if op.is_some() {
self.outputter.push_char(')');
};
match heap_val {
- HeapCellValue::NamedStr(arity, ref name, Some(fixity)) if name.as_str() != "," => {
+ HeapCellValue::NamedStr(arity, ref name, Some(spec)) if name.as_str() != "," => {
if op.is_some() {
self.state_stack.push(TokenOrRedirect::Close);
}
- let ct = ClauseType::from(name.clone(), arity, Some(fixity));
+ let ct = ClauseType::from(name.clone(), arity, Some(spec));
self.format_clause(iter, arity, ct);
if let Some(ref op) = op {
match loc_data {
TokenOrRedirect::Atom(atom) =>
self.print_atom(&atom, None),
- TokenOrRedirect::Op(atom, fixity) =>
- self.print_atom(&atom, Some(fixity)),
+ TokenOrRedirect::Op(atom, spec) =>
+ self.print_atom(&atom, Some(spec)),
TokenOrRedirect::NumberedVar(num_var) =>
self.outputter.append(num_var.as_str()),
TokenOrRedirect::CompositeRedirect(op) =>
self.outputter.push_char(']');
},
TokenOrRedirect::HeadTailSeparator =>
-// if !self.ignore_ops {
- self.outputter.append(" | "),
-// },
+ self.outputter.append(" | "),
TokenOrRedirect::Comma =>
self.outputter.append(", ")
}
}
impl SystemClauseType {
- pub fn fixity(&self) -> Option<Fixity> {
- None
- }
-
pub fn name(&self) -> ClauseName {
match self {
&SystemClauseType::CheckCutPoint => clause_name!("$check_cp"),
Hook(CompileTimeHook),
Inlined(InlinedClauseType),
Named(ClauseName, CodeIndex),
- Op(ClauseName, Fixity, CodeIndex),
+ Op(OpDecl, CodeIndex),
System(SystemClauseType)
}
impl BuiltInClauseType {
- fn fixity(&self) -> Option<Fixity> {
- match self {
- &BuiltInClauseType::Compare | &BuiltInClauseType::CompareTerm(_)
- | &BuiltInClauseType::NotEq | &BuiltInClauseType::Is(..) | &BuiltInClauseType::Eq
- => Some(Fixity::In),
- _ => None
- }
- }
-
pub fn name(&self) -> ClauseName {
match self {
&BuiltInClauseType::AcyclicTerm => clause_name!("acyclic_term"),
}
impl ClauseType {
- pub fn fixity(&self) -> Option<Fixity> {
- match self {
- &ClauseType::BuiltIn(ref built_in) => built_in.fixity(),
- &ClauseType::Inlined(InlinedClauseType::CompareNumber(..)) => Some(Fixity::In),
- &ClauseType::Op(_, fixity, _) => Some(fixity),
- &ClauseType::System(ref system) => system.fixity(),
+ pub fn spec(&self) -> Option<(usize, Specifier)> {
+ match self {
+ &ClauseType::Op(ref op_decl, _) =>
+ Some((op_decl.0, op_decl.1)),
+ &ClauseType::Inlined(InlinedClauseType::CompareNumber(..))
+ | &ClauseType::BuiltIn(BuiltInClauseType::Is(..))
+ | &ClauseType::BuiltIn(BuiltInClauseType::CompareTerm(_))
+ | &ClauseType::BuiltIn(BuiltInClauseType::NotEq)
+ | &ClauseType::BuiltIn(BuiltInClauseType::Eq) =>
+ Some((700, XFX)),
_ => None
}
}
&ClauseType::BuiltIn(ref built_in) => built_in.name(),
&ClauseType::Hook(ref hook) => hook.name(),
&ClauseType::Inlined(ref inlined) => clause_name!(inlined.name()),
- &ClauseType::Op(ref name, ..) => name.clone(),
+ &ClauseType::Op(ref op_decl, ..) => op_decl.name(),
&ClauseType::Named(ref name, ..) => name.clone(),
&ClauseType::System(ref system) => system.name(),
}
}
- pub fn from(name: ClauseName, arity: usize, fixity: Option<Fixity>) -> Self {
+ pub fn from(name: ClauseName, arity: usize, spec: Option<(usize, Specifier)>) -> Self {
InlinedClauseType::from(name.as_str(), arity)
.map(ClauseType::Inlined)
.unwrap_or_else(|| {
SystemClauseType::from(name.as_str(), arity)
.map(ClauseType::System)
.unwrap_or_else(|| {
- if let Some(fixity) = fixity {
- ClauseType::Op(name, fixity, CodeIndex::default())
+ if let Some(spec) = spec {
+ let op_decl = OpDecl(spec.0, spec.1, name);
+ ClauseType::Op(op_decl, CodeIndex::default())
} else if name.as_str() == "call" {
ClauseType::CallN
} else {
#[derive(Clone, PartialEq)]
pub enum HeapCellValue {
Addr(Addr),
- NamedStr(usize, ClauseName, Option<Fixity>), // arity, name, fixity if it has one.
+ NamedStr(usize, ClauseName, Option<(usize, Specifier)>), // arity, name, fixity if it has one.
}
impl HeapCellValue {
match term {
&Term::AnonVar =>
TermIterState::AnonVar(lvl),
- &Term::Clause(ref cell, ref name, ref subterms, fixity) => {
- let ct = if let Some(fixity) = fixity {
- ClauseType::Op(name.clone(), fixity, CodeIndex::default())
+ &Term::Clause(ref cell, ref name, ref subterms, spec) => {
+ let ct = if let Some(spec) = spec {
+ let op_decl = OpDecl(spec.0, spec.1, name.clone());
+ ClauseType::Op(op_decl, CodeIndex::default())
} else {
ClauseType::Named(name.clone(), CodeIndex::default())
};
pub struct OpDecl(pub usize, pub Specifier, pub ClauseName);
impl OpDecl {
+ #[inline]
+ pub fn name(&self) -> ClauseName {
+ self.2.clone()
+ }
+
pub fn submit(&self, module: ClauseName, op_dir: &mut OpDir) -> Result<(), SessionError>
{
let (prec, spec, name) = (self.0, self.1, self.2.clone());
impl MachineError {
pub(super) fn functor_stub(name: ClauseName, arity: usize) -> MachineStub {
let name = HeapCellValue::Addr(Addr::Con(Constant::Atom(name, None)));
- functor!("/", 2, [name, heap_integer!(arity)], Fixity::In)
+ functor!("/", 2, [name, heap_integer!(arity)], (400, YFX))
}
pub(super) fn evaluation_error(eval_error: EvalError) -> Self {
stub.append(&mut functor!("/", 2, [HeapCellValue::Addr(Addr::HeapCell(h + 2 + 3)),
heap_integer!(arity)],
- Fixity::In));
- stub.append(&mut functor!(":", 2, [mod_name, name], Fixity::In));
+ (400, YFX)));
+ stub.append(&mut functor!(":", 2, [mod_name, name], (600, XFY)));
MachineError { stub, from: ErrorProvenance::Constructed }
}
loop {
match self.heap[new_l].clone() {
HeapCellValue::Addr(Addr::Str(l)) => new_l = l,
- HeapCellValue::NamedStr(2, ref name, Some(Fixity::In))
+ HeapCellValue::NamedStr(2, ref name, Some(_))
if name.as_str() == "-" => break,
HeapCellValue::Addr(Addr::HeapCell(_)) => break,
HeapCellValue::Addr(Addr::StackCell(..)) => break,
// see 8.4.4 of Draft Technical Corrigendum 2.
pub(super) fn check_keysort_errors(&self) -> CallResult {
- let stub = MachineError::functor_stub(clause_name!("keysort"), 2);
+ let stub = MachineError::functor_stub(clause_name!("keysort"), 2);
let pairs = self.store(self.deref(self[temp_v!(1)].clone()));
let sorted = self.store(self.deref(self[temp_v!(2)].clone()));
for heap_val in self.post_order_iter(a) {
match heap_val {
- HeapCellValue::NamedStr(2, name, Some(Fixity::In)) => {
+ HeapCellValue::NamedStr(2, name, Some(_)) => {
let a2 = interms.pop().unwrap();
let a1 = interms.pop().unwrap();
caller))
}
},
- HeapCellValue::NamedStr(1, name, Some(Fixity::Pre)) => {
+ HeapCellValue::NamedStr(1, name, Some(_)) => {
let a1 = interms.pop().unwrap();
match name.as_str() {
let h = self.heap.h;
self.heap.push(HeapCellValue::Addr(Addr::Str(h + 1)));
- self.heap.push(HeapCellValue::NamedStr(arity, ct.name(), ct.fixity()));
+ self.heap.push(HeapCellValue::NamedStr(arity, ct.name(), ct.spec()));
self.bind(addr.as_var().unwrap(), Addr::HeapCell(h));
&QueryInstruction::PutStructure(ref ct, arity, reg) => {
let h = self.heap.h;
- self.heap.push(HeapCellValue::NamedStr(arity, ct.name(), ct.fixity()));
+ self.heap.push(HeapCellValue::NamedStr(arity, ct.name(), ct.spec()));
self[reg] = Addr::Str(h);
},
&QueryInstruction::PutUnsafeValue(n, arg) => {
Err(self.error_form(MachineError::instantiation_error(), stub)),
Addr::Str(s) =>
match self.heap[s].clone() {
- HeapCellValue::NamedStr(2, ref name, Some(Fixity::In))
+ HeapCellValue::NamedStr(2, ref name, Some(_))
if *name == clause_name!("-") =>
Ok(Addr::HeapCell(s+1)),
_ => Err(self.error_form(MachineError::type_error(ValidType::Pair,
try_or_fail!(self, call_policy.compile_hook(self, hook)),
&ClauseType::Inlined(ref ct) =>
self.execute_inlined(ct),
- &ClauseType::Named(ref name, ref idx) | &ClauseType::Op(ref name, _, ref idx) =>
+ &ClauseType::Named(ref name, ref idx) | &ClauseType::Op(OpDecl(.., ref name), ref idx) =>
try_or_fail!(self, call_policy.context_call(self, name.clone(), arity, idx.clone(),
indices)),
&ClauseType::System(ref ct) =>
},
&TermRef::Clause(lvl, _, ref ct, subterms) => {
queue.push_back((subterms.len(), h+1));
- let named = HeapCellValue::NamedStr(subterms.len(), ct.name(), ct.fixity());
+ let named = HeapCellValue::NamedStr(subterms.len(), ct.name(), ct.spec());
machine_st.heap.push(named);
}
}
- fn get_clause_type(&mut self, name: ClauseName, arity: usize, fixity: Option<Fixity>) -> ClauseType
+ fn get_clause_type(&mut self, name: ClauseName, arity: usize, spec: Option<(usize, Specifier)>) -> ClauseType
{
- match ClauseType::from(name, arity, fixity) {
+ match ClauseType::from(name, arity, spec) {
ClauseType::Named(name, _) => {
let idx = self.get_code_index(name.clone(), arity);
ClauseType::Named(name, idx.clone())
},
- ClauseType::Op(name, fixity, _) => {
- let idx = self.get_code_index(name.clone(), arity);
- ClauseType::Op(name, fixity, idx.clone())
+ ClauseType::Op(op_decl, _) => {
+ let idx = self.get_code_index(op_decl.2.clone(), arity);
+ ClauseType::Op(op_decl, idx.clone())
},
ct => ct
}
fn setup_predicate_export(mut term: Term) -> Result<PredicateKey, ParserError>
{
match term {
- Term::Clause(_, ref name, ref mut terms, Some(Fixity::In))
+ Term::Clause(_, ref name, ref mut terms, Some(_))
if name.as_str() == "/" && terms.len() == 2 => {
let arity = *terms.pop().unwrap();
let name = *terms.pop().unwrap();
impl fmt::Display for ClauseType {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match self {
- &ClauseType::Named(ref name, ref idx) | &ClauseType::Op(ref name, _, ref idx) => {
+ &ClauseType::Named(ref name, ref idx) | &ClauseType::Op(OpDecl(.., ref name), ref idx) =>
+ {
let idx = idx.0.borrow();
write!(f, "{}:{}/{}", idx.1, name, idx.0)
},
println!("true.");
return;
}
-
+
if !wam.or_stack_is_empty() {
println!("true .");
}