Files
mercury/tests/submodules/external_unification_pred.m
Zoltan Somogyi c27258ae9c Update the style of tests/submodules/*.m.
Disable irrelevant warnings for a test case.
2021-07-25 14:30:37 +10:00

83 lines
1.9 KiB
Mathematica

%---------------------------------------------------------------------------%
% vim: ts=4 sw=4 et ft=mercury
%---------------------------------------------------------------------------%
%
% The mercury compiler from 2003-12-01 generated uncompilable il code for this
% test case.
:- module external_unification_pred.
:- interface.
:- import_module io.
:- pred main(io::di, io::uo) is det.
:- implementation.
:- module external_unification_pred.sub.
:- interface.
:- type ft.
:- func create_ft(int) = ft.
:- implementation.
:- pragma foreign_type(c, ft, "int") where equality is unify_ft.
:- pragma foreign_type("C#", ft, "int") where equality is unify_ft.
:- pragma foreign_type(java, ft, "Integer") where equality is unify_ft.
:- pred unify_ft(ft::in, ft::in) is semidet.
:- pragma foreign_proc("C",
unify_ft(X::in, Y::in),
[promise_pure],
"
SUCCESS_INDICATOR = (X == Y);
").
:- pragma foreign_proc("C#",
unify_ft(X::in, Y::in),
[promise_pure],
"
SUCCESS_INDICATOR = (X == Y);
").
:- pragma foreign_proc("Java",
unify_ft(X::in, Y::in),
[promise_pure],
"
SUCCESS_INDICATOR = (X == Y);
").
:- pragma foreign_proc("C",
create_ft(X::in) = (Y::out),
[promise_pure],
"
Y = X;
").
:- pragma foreign_proc("C#",
create_ft(X::in) = (Y::out),
[promise_pure],
"
Y = X;
").
:- pragma foreign_proc("Java",
create_ft(X::in) = (Y::out),
[promise_pure],
"
Y = X;
").
:- end_module external_unification_pred.sub.
:- import_module external_unification_pred.sub.
main(!IO) :-
X = create_ft(1),
Y = create_ft(2),
( if X = Y then
io.write_string("true.\n", !IO)
else
io.write_string("false.\n", !IO)
).
:- end_module external_unification_pred.