mirror of
https://github.com/Mercury-Language/mercury.git
synced 2026-04-16 18:03:36 +00:00
tests/warnings/*.m:
Bring the programming style of these modules up to date,
except where the problem being tested for seems to be related
to the old programming style
In the infinite_recursion test case, add code that we *should*
warn about, but currently don't.
tests/warnings/*.m:
Update the expected outputs to account for the changes in line
numbers, and the fact that the compiler computes the contexts
of (if C then T else E) if-then-elses differently from (C -> T; E)
if-then-else (it takes the context of the "then" vs the context
of the ";").
Delete arg_order_rearrangment.exp2. It was long unused, but
deleting it in CVS would not have allowed us to put it back later.
23 lines
752 B
Mathematica
23 lines
752 B
Mathematica
%---------------------------------------------------------------------------%
|
|
% vim: ts=4 sw=4 et ft=mercury
|
|
%---------------------------------------------------------------------------%
|
|
%
|
|
% This test case should produce _no_ warnings. One version of the compiler
|
|
% complained that the recursive call to return_me inside the lambda
|
|
% would cause infinite recursion. -- 28/7/1997 bromage
|
|
%
|
|
%---------------------------------------------------------------------------%
|
|
|
|
:- module inf_recursion_lambda.
|
|
:- interface.
|
|
|
|
:- type closure
|
|
---> closure((func) = closure).
|
|
:- inst closure == bound(closure((func) = out(closure) is det)).
|
|
|
|
:- func return_me = (closure :: out(closure)) is det.
|
|
|
|
:- implementation.
|
|
|
|
return_me = closure((func) = return_me).
|