Files
mercury/tests/invalid/multimode_syntax.m
Peter Ross 4c71c5db87 Gets the tests in tests/invalid working in the il grade.
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.
2002-11-07 16:17:09 +00:00

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(_).