Files
mercury/tests/submodules/nested2.m
2021-07-25 14:40:53 +10:00

73 lines
1.8 KiB
Mathematica

%---------------------------------------------------------------------------%
% vim: ts=4 sw=4 et ft=mercury
%---------------------------------------------------------------------------%
%
% Another test case to test nested modules.
:- module nested2.
:- interface.
:- import_module io.
:- pred hello(io::di, io::uo) is det.
%---------------------------------------------------------------------------%
:- module nested2.child.
:- interface.
% module `io' is imported in nested2
:- type t1 == foo.
:- type t2 == nested2.foo.
:- pred main(io::di, io::uo) is det.
:- end_module nested2.child.
%---------------------------------------------------------------------------%
:- implementation.
:- module nested2.child.
:- implementation.
:- import_module std_util.
:- import_module type_desc.
:- type t3 == foo.
:- type t4 == nested2.foo.
:- func has_type_t1 = t1.
:- func has_type_t2 = t2.
:- func has_type_t3 = t3.
:- func has_type_t4 = t4.
has_type_t1 = bar.
has_type_t2 = nested2.bar.
has_type_t3 = baz(42).
has_type_t4 = nested2.baz(42).
main(!IO) :-
nested2.hello(!IO),
hello(!IO),
io.print("t1 = ", !IO), io.print_line(type_of(has_type_t1), !IO),
io.print("t2 = ", !IO), io.print_line(type_of(has_type_t2), !IO),
io.print("t3 = ", !IO), io.print_line(type_of(has_type_t3), !IO),
io.print("t4 = ", !IO), io.print_line(type_of(has_type_t4), !IO),
io.print("has_type_t1 = ", !IO), io.print_line(has_type_t1, !IO),
io.print("has_type_t2 = ", !IO), io.print_line(has_type_t2, !IO),
io.print("has_type_t3 = ", !IO), io.print_line(has_type_t3, !IO),
io.print("has_type_t4 = ", !IO), io.print_line(has_type_t4, !IO).
:- end_module nested2.child.
:- type foo
---> bar
; baz(int).
hello(!IO) :-
io.print("nested2.hello\n", !IO).
:- end_module nested2.