Files
mercury/tests/general/unsafe_uniqueness.m
Zoltan Somogyi ecb5e4a9e6 Update the style of many test cases.
tests/declarative_debugger/*.m:
tests/exceptions/*.m:
tests/general/*.m:
tests/grade_subdirs/*.m:
tests/purity/*.m:
tests/submodules/*.m:
tests/typeclasses/*.m:
    Update programming style.

tests/declarative_debugger/*.inp:
    Update line numbers in breakpoint commands.
tests/declarative_debugger/*.exp:
    Update expected line numbers.

tests/exceptions/Mercury.options:
tests/general/Mercury.options:
    Disable some warnings that are irrelevant to the test.
2021-07-25 23:26:17 +10:00

41 lines
1.2 KiB
Mathematica

%---------------------------------------------------------------------------%
% vim: ts=4 sw=4 et ft=mercury
%---------------------------------------------------------------------------%
% unsafe_uniqueness.m
% Ralph Becket <rafe@cs.mu.oz.au>
% Wed Dec 19 13:42:42 EST 2001
%
% Test of built-in unsafe_promise_unique/1. This shouldn't compile
% if there is a problem with unsafe_promise_unique/1.
%
%---------------------------------------------------------------------------%
:- module unsafe_uniqueness.
:- interface.
:- import_module io.
:- type wrapper(T)
---> wrapper(T).
:- func unwrap(wrapper(T)) = T.
:- mode unwrap(di) = uo is det.
:- pred main(io::di, io::uo) is det.
%---------------------------------------------------------------------------%
%---------------------------------------------------------------------------%
:- implementation.
unwrap(wrapper(X)) = unsafe_promise_unique(X).
%---------------------------------------------------------------------------%
main(!IO) :-
io.print("I must have compiled!\n", !IO).
%---------------------------------------------------------------------------%
%---------------------------------------------------------------------------%