Files
mercury/tests/invalid_purity/purity.m
Zoltan Somogyi 62d9fcbe4b Ignore (mostly) comments inside foreign_procs.
compiler/foreign.m:
    When returning the list of identifiers inside a foreign_proc's code,
    ignore the contents of comments. This means that warnings about
    variable names that occur in the foreign_proc's argument list
    but do not occur in the foreign_proc's code cannot be shut up anymore
    by mention the variable name in comments.

    The "mostly" part is that typecheck.m still looks at the bodies
    of foreign_procs without knowing about comments. Fixing that
    will be part a future change.

NEWS.md:
    Announce this breaking change.

compiler/fact_table_gen.m:
    When we try to generate a foreign_proc's body for a fact table
    but cannot do so due to the fact table file not being readable,
    add a marker to the predicate that the fact table is for.

compiler/hlds_markers.m:
    Update the documentation of the existing predicate marker
    we use for this.

compiler/make_hlds_warn.m:
    Do not warn about singleton variables in foreign_proc bodies
    that are empty due to missing fact table files.

library/array.m:
library/io.file.m:
library/profiling_builtin.m:
library/stm_builtin.m:
library/table_builtin.m:
library/term_size_prof_builtin.m:
tests/invalid/erroneous_throw_promise.m:
tests/invalid/foreign_procs_exist_type.m:
tests/invalid/foreign_purity_mismatch.m:
tests/invalid/gh72_errors.m:
tests/invalid_purity/purity.m:
tests/valid/solv.m:
    Shut up warnings about singletons in foreign_procs by adding a _ prefix
    to the names of the relevant arguments, and delete the comments
    that can no longer do that job.

tests/invalid/foreign_purity_mismatch.err_exp:
tests/invalid/gh72_errors.err_exp:
tests/invalid/gh72_errors.err_exp2:
tests/invalid/gh72_errors.err_exp3:
tests/invalid_purity/purity.err_exp:
    Expect updated line numbers.

tests/warnings/warn_return.{m,err_exp}:
    Extend this test case to test that

    - we DO warn about return statements outside comments, but
    - we DO NOT warn about return statements inside comments.
2026-01-28 13:34:30 +11:00

224 lines
3.5 KiB
Mathematica

%---------------------------------------------------------------------------%
% vim: ts=4 sw=4 et ft=mercury
%---------------------------------------------------------------------------%
:- module purity.
:- interface.
% This type is used by the tests below.
:- type foo
---> a
; b.
:- implementation.
:- impure pred imp is det.
:- pragma foreign_proc("C",
imp,
[will_not_call_mercury],
"
;
").
:- pragma foreign_proc("Java",
imp,
[will_not_call_mercury],
"
;
").
:- pragma foreign_proc("C#",
imp,
[will_not_call_mercury],
"
;
").
imp.
:- semipure pred semi is semidet.
:- pragma foreign_proc("C",
semi,
[promise_semipure, will_not_call_mercury],
"
SUCCESS_INDICATOR = 0;
").
:- pragma foreign_proc("Java",
semi,
[promise_semipure, will_not_call_mercury],
"
SUCCESS_INDICATOR = false;
").
:- pragma foreign_proc("C#",
semi,
[promise_semipure, will_not_call_mercury],
"
SUCCESS_INDICATOR = false;
").
semi :-
semidet_fail.
:- pred in(foo::in) is semidet.
in(a).
:- semipure pred semi(foo::in) is semidet.
:- pragma foreign_proc("C",
semi(_X::in),
[will_not_call_mercury, promise_semipure],
"
SUCCESS_INDICATOR = 0;
").
:- pragma foreign_proc("Java",
semi(_X::in),
[will_not_call_mercury, promise_semipure],
"
SUCCESS_INDICATOR = false;
").
:- pragma foreign_proc("C#",
semi(_X::in),
[will_not_call_mercury, promise_semipure],
"
SUCCESS_INDICATOR = false;
").
:- impure pred imp1(foo).
:- mode imp1(in) is semidet.
:- pragma foreign_proc("C",
imp1(_X::in),
[will_not_call_mercury],
"
SUCCESS_INDICATOR = 0;
").
:- pragma foreign_proc("Java",
imp1(_X::in),
[will_not_call_mercury],
"
SUCCESS_INDICATOR = false;
").
:- pragma foreign_proc("C#",
imp1(_X::in),
[will_not_call_mercury],
"
SUCCESS_INDICATOR = false;
").
imp1(_) :-
semidet_fail.
%----------------------------------------------------------------
% Warnings.
:- impure pred w1 is det.
w1.
:- semipure pred w2 is det.
w2.
:- impure pred w3 is semidet.
w3 :-
semipure semi.
:- pred w4 is det.
:- pragma promise_pure(w4/0).
w4.
:- impure pred w5 is det.
:- pragma promise_pure(w5/0).
w5 :-
impure imp.
:- semipure pred w6 is semidet.
:- pragma promise_pure(w6/0).
w6 :-
semipure semi.
%----------------------------------------------------------------
% Errors.
:- pred e1 is det.
e1 :-
impure imp.
:- pred e2 is semidet.
e2 :-
semipure semi.
:- semipure pred e3 is det.
e3 :-
impure imp.
:- impure pred e4 is det.
e4 :-
imp.
:- semipure pred e5 is semidet.
e5 :-
semi.
:- impure pred e6 is semidet.
e6 :-
in(X),
impure imp,
X = a.
:- impure pred e7 is semidet.
e7 :-
impure imp1(X),
X = a.
:- type e8
---> e8(foo)
where equality is imp2.
:- impure pred imp2(e8::in, e8::in) is semidet.
:- pragma foreign_proc("C",
imp2(_X::in, _Y::in),
[will_not_call_mercury],
"
SUCCESS_INDICATOR = 0;
").
imp2(_, _) :-
semidet_fail.
:- type e9
---> e9(foo)
where equality is semi2.
:- semipure pred semi2(e9::in, e9::in) is semidet.
:- pragma foreign_proc("C",
semi2(_X::in, _Y::in),
[promise_semipure, will_not_call_mercury],
"
SUCCESS_INDICATOR = 0;
").
semi2(_, _) :-
semidet_fail.
:- pred e10 is semidet.
e10 :-
Goal1 = (pred(X::in) is semidet :- imp1(X)),
call(Goal1, b).
:- pred e11 is semidet.
e11 :-
Goal2 = (pred(X::in) is semidet :- semi(X)),
call(Goal2, b).