Files
mercury/tests/valid/complex_failure.m
Zoltan Somogyi c03b11ca48 Update the style of more test cases.
And updated expected outputs for changed line numbers.
2021-07-27 19:29:21 +10:00

132 lines
2.6 KiB
Mathematica

%---------------------------------------------------------------------------%
% vim: ts=4 sw=4 et ft=mercury
%---------------------------------------------------------------------------%
%
% This test case is a copy of tests/general/complex_failure, and tests
% whether this test case can be compiled with --use-trail; this caused
% a compiler abort with the 21 September, 1998 version of the compiler.
%
% Unfortunately, we cannot just specify --use-trail for complex_failure
% in tests/general, since that would cause a link error in the usual case
% that the runtime being linked with is not in a trailing grade.
:- module complex_failure.
:- interface.
:- import_module io.
:- pred main(io::di, io::uo) is det.
:- implementation.
:- import_module int.
:- import_module list.
:- import_module solutions.
main(!IO) :-
solutions(p1, Xs1),
print_list(Xs1, !IO),
solutions(p2, Xs2),
print_list(Xs2, !IO),
solutions(p3, Xs3),
print_list(Xs3, !IO).
:- pred p1(int::out) is nondet.
p1(X) :-
p(1, X).
:- pred p2(int::out) is nondet.
p2(X) :-
p(2, X).
:- pred p3(int::out) is nondet.
p3(X) :-
p(3, X).
:- pred p(int::in, int::out) is nondet.
p(A, X) :-
% The first if-then-else can hijack the redoip/redofr slots
% of p's frame.
( if
some [B] ( q(A, B) ; r(A, B) )
then
C = B * 10
% s(B, C)
else
C = A * 10
% s(A, C)
),
% The second if-then-else cannot hijack the redoip/redofr slots
% of p's frame, since this may not be (and usually won't be)
% on top when execution gets here.
( if
some [D] ( q(C, D) ; r(C, D) )
then
s(D, X)
else
s(C, X)
).
:- pred q(int::in, int::out) is nondet.
q(1, 15).
q(1, 16).
q(2, 25).
q(2, 26).
q(3, 35).
q(150, 660).
q(161, 661).
q(281, 662).
:- pred r(int::in, int::out) is nondet.
r(1, 18).
r(1, 19).
r(2, 28).
r(2, 29).
r(3, 38).
r(260, 690).
r(370, 698).
:- pred s(int::in, int::out) is nondet.
s(F, G) :-
F < 695,
(
G = 10 * F
;
G = 10 * F + 1
).
:- pred print_list(list(int)::in, io::di, io::uo) is det.
print_list(Xs, !IO) :-
(
Xs = [],
io.write_string("[]\n", !IO)
;
Xs = [_ | _],
io.write_string("[", !IO),
print_list_2(Xs,!IO),
io.write_string("]\n", !IO)
).
:- pred print_list_2(list(int)::in, io::di, io::uo) is det.
print_list_2([], !IO).
print_list_2([X | Xs], !IO) :-
io.write_int(X, !IO),
(
Xs = []
;
Xs = [_ | _],
io.write_string(", ", !IO),
print_list_2(Xs, !IO)
).