Files
mercury/tests/submodules/nested2.m
Zoltan Somogyi fdd141bf77 Clean up the tests in the other test directories.
tests/invalid/*.{m,err_exp}:
tests/misc_tests/*.m:
tests/mmc_make/*.m:
tests/par_conj/*.m:
tests/purity/*.m:
tests/stm/*.m:
tests/string_format/*.m:
tests/structure_reuse/*.m:
tests/submodules/*.m:
tests/tabling/*.m:
tests/term/*.m:
tests/trailing/*.m:
tests/typeclasses/*.m:
tests/valid/*.m:
tests/warnings/*.{m,exp}:
    Make these tests use four-space indentation, and ensure that
    each module is imported on its own line. (I intend to use the latter
    to figure out which subdirectories' tests can be executed in parallel.)

    These changes usually move code to different lines. For the tests
    that check compiler error messages, expect the new line numbers.

browser/cterm.m:
browser/tree234_cc.m:
    Import only one module per line.

tests/hard_coded/boyer.m:
    Fix something I missed.
2015-02-16 12:32:18 +11:00

73 lines
1.7 KiB
Mathematica

%---------------------------------------------------------------------------%
% vim: ts=4 sw=4 et ft=mercury
%---------------------------------------------------------------------------%
%
% Another test case to test nested modules.
:- module nested2.
:- interface.
:- import_module io.
%---------------------------------------------------------------------------%
:- module nested2.child.
:- interface.
% module `io' is imported in nested2
:- type t1 == foo.
:- type t2 == nested2.foo.
:- pred main(io__state::di, io__state::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 -->
nested2.hello,
hello,
print("t1 = "), print(type_of(has_type_t1)), nl,
print("t2 = "), print(type_of(has_type_t2)), nl,
print("t3 = "), print(type_of(has_type_t3)), nl,
print("t4 = "), print(type_of(has_type_t4)), nl,
print("has_type_t1 = "), print(has_type_t1), nl,
print("has_type_t2 = "), print(has_type_t2), nl,
print("has_type_t3 = "), print(has_type_t3), nl,
print("has_type_t4 = "), print(has_type_t4), nl.
:- end_module nested2.child.
:- type foo
---> bar
; baz(int).
:- pred hello(io__state::di, io__state::uo) is det.
hello -->
print("nested2.hello\n").
:- end_module nested2.