&Constant::Atom(ref atom) =>
write!(f, "{}", atom),
&Constant::Char(c) =>
- write!(f, "{}", c as u8),
+ write!(f, "'{}'", c as u8),
&Constant::EmptyList =>
write!(f, "[]"),
&Constant::Number(ref n) =>
keysort_execute!(), // keysort/2, 484.
acyclic_term_execute!(), // acyclic_term/1, 485.
cyclic_term_execute!(), // cyclic_term/1, 486.
+ skip_max_list_execute!() // '$skip_max_list', 487.
]
}
code_dir.insert((clause_name!("keysort"), 2), CodeIndex::from((484, builtin.clone())));
code_dir.insert((clause_name!("acyclic_term"), 1), CodeIndex::from((485, builtin.clone())));
code_dir.insert((clause_name!("cyclic_term"), 1), CodeIndex::from((486, builtin.clone())));
-
+ code_dir.insert((clause_name!("$skip_max_list"), 4), CodeIndex::from((487, builtin.clone())));
+
(code_dir, op_dir)
}
(clause_name!("sort"), 2),
(clause_name!("keysort"), 2),
(clause_name!("acyclic_term"), 1),
- (clause_name!("cyclic_term"), 1)]);
+ (clause_name!("cyclic_term"), 1),
+ (clause_name!("$skip_max_list"), 4)]);
for arity in 0 .. 63 {
module_decl.exports.push((clause_name!("call"), arity));
},
HeapCellValue::Addr(Addr::Con(Constant::EmptyList)) =>
return CycleSearchResult::PartialOrProperList(steps, hare),
- HeapCellValue::Addr(Addr::HeapCell(hc)) if hc == hare =>
- return CycleSearchResult::PartialOrProperList(steps, hare),
+ HeapCellValue::Addr(ref hc @ Addr::HeapCell(_))
+ if Addr::HeapCell(hare) == self.store(self.deref(hc.clone())) =>
+ return CycleSearchResult::PartialOrProperList(steps, hare),
HeapCellValue::Addr(ref sc @ Addr::StackCell(..))
if *sc == self.store(self.deref(sc.clone())) =>
return CycleSearchResult::PartialOrProperList(steps, hare),
======================================================================================
?N, -Xs0 : N = 0, Xs = Xs0.
?N, +Xs0 : Xs0 is a proper or partial list, Xs0 = [X1, X2, ..., XN | Xs], N = Max,
- if |Xs0| >= Max, or, Xs = [] and N = |Xs0|.
+ if |Xs0| >= Max, or, Xs = Xs0 and N = |Xs0|.
*/
pub(super) fn skip_max_list(&mut self) {
let max = self.store(self.deref(self[temp_v!(2)].clone()));
self.finalize_skip_max_list(0, Addr::Con(Constant::EmptyList)),
CycleSearchResult::PartialOrProperList(n, hc) =>
self.finalize_skip_max_list(n, Addr::HeapCell(hc)),
- CycleSearchResult::NotList =>
- self.fail = true
+ CycleSearchResult::NotList => {
+ let xs0 = self[temp_v!(3)].clone();
+ self.finalize_skip_max_list(0, xs0);
+ }
}
}
}
)
}
+macro_rules! skip_max_list_execute {
+ () => (
+ Line::Control(ControlInstruction::CallClause(ClauseType::SkipMaxList, 4, 0, true))
+ )
+}
+
macro_rules! return_from_clause {
($lco:expr, $machine_st:expr) => {{
if $lco {
assert_prolog_failure!(&mut wam, "?- Xs = [a,b|Xs], '$skip_max_list'(3, 5, X, Xs0).");
assert_prolog_failure!(&mut wam, "?- X = [a,b|Y], Y = [c,d|X], '$skip_max_list'(4, 5, X, Xs0).");
assert_prolog_failure!(&mut wam, "?- X = [a,b|Y], Y = [c,d|X], '$skip_max_list'(4, 3, X, Xs0).");
+
+ // tests on non lists.
+ assert_prolog_success!(&mut wam, "?- '$skip_max_list'(N, 9, non_list, Xs).",
+ [["Xs = non_list", "N = 0"]]);
}