mirror of
https://github.com/Mercury-Language/mercury.git
synced 2025-12-21 00:39:37 +00:00
Estimated hours taken: 3 Branches: main Gets the tests in tests/invalid working in the il grade. compiler/options.m: Add a new developer option, --no-automatic-intermodule-optimization. This is used to turn off intermodule optimization in the tests/invalid directory so that the error messages are no longer generated during the --make-optimization-interface process. compiler/handle_options.m: Test automatic-intermodule-optimization when determining whether to turn intermodule optimization on in the il grade. tests/invalid/Mercury.options: tests/invalid/purity/Mercury.options: Add --no-automatic-intermodule-optimization. tests/invalid/foreign_singleton.err_exp2: tests/invalid/foreign_type_2.err_exp2: tests/invalid/pragma_c_code_dup_var.err_exp2: tests/invalid/pragma_c_code_no_det.err_exp2: Add a second expected error message for non C backends. tests/invalid/impure_method_impl.m: tests/invalid/multimode_missing_impure.m: tests/invalid/multimode_syntax.m: tests/invalid/pragma_c_code_no_det.m: tests/invalid/purity/impure_func_t2.m: tests/invalid/purity/impure_func_t3.m: tests/invalid/purity/impure_func_t4.m: tests/invalid/purity/impure_func_t5.m: tests/invalid/purity/impure_func_t7.m: tests/invalid/purity/impure_pred_t1.m: tests/invalid/purity/impure_pred_t2.m: tests/invalid/purity/purity.m: Add Mercury implementations of foreign_code predicates.
57 lines
1.7 KiB
Mathematica
57 lines
1.7 KiB
Mathematica
:- module multimode_syntax.
|
|
:- interface.
|
|
:- import_module io.
|
|
|
|
:- pred main(state::di, state::uo) is det.
|
|
|
|
:- implementation.
|
|
|
|
main --> [].
|
|
|
|
:- func func0 = string.
|
|
:- mode func0 = out is det.
|
|
func0 = "func0 = out" :: out. % missing parentheses
|
|
|
|
:- func func1(int) = string.
|
|
:- mode func1(in) = out is det.
|
|
:- mode func1(out) = out is det.
|
|
func1(_::in) = "func1(in) = out". % missing mode annotation on return value
|
|
func1(0) = ("func1(out) = out" :: out). % missing mode annotation on argument
|
|
|
|
:- func func2(int, int) = string.
|
|
:- mode func2(in, in) = out is det.
|
|
func2(_::in, _::in) = (R::out) :-
|
|
R = "func2(in, in) = out".
|
|
func2(_::in, 0::out) = (R::out) :- % reference to undeclared mode
|
|
R = "func2(in, out) = out".
|
|
func2(0::out, _::in) = (R::out) :-
|
|
R = "func2(out, in) = out".
|
|
func2(0::out, 0::out) = (R::out) :-
|
|
R = "func2(out, out) = out".
|
|
|
|
:- func func2b(int, int) = string.
|
|
func2b(_::in, _::out) = (R::out) :- % another reference to undeclared mode
|
|
R = "func3(in, out) = out".
|
|
|
|
:- impure pred pred2b(int, int).
|
|
pred2b(_::in, 0::out) :- % another reference to undeclared mode
|
|
impure puts("func3(in, out) = out").
|
|
|
|
:- impure pred test2(int, int).
|
|
:- mode test2(in, in) is det.
|
|
:- mode test2(in, out) is det.
|
|
:- mode test2(out, in) is det.
|
|
:- mode test2(out, out) is det.
|
|
test2(_::in, _) :- % missing mode annotation on 2nd arg
|
|
impure puts("test2(in, in)").
|
|
test2(_, 0::out) :- % missing mode annotation on 1st arg
|
|
impure puts("test2(in, out)").
|
|
test2(0::out, _::in) :-
|
|
impure puts("test2(out, in)").
|
|
test2(0::out, 0::out) :-
|
|
impure puts("test2(out, out)").
|
|
|
|
:- impure pred puts(string::in) is det.
|
|
:- pragma c_code(puts(S::in), [will_not_call_mercury], "puts(S)").
|
|
puts(_).
|