mirror of
https://github.com/Mercury-Language/mercury.git
synced 2026-04-20 11:54:02 +00:00
library/*.m:
Specifically, delete any predicates and functions whose `pragma obsolete'
dates from 2018 or before. Keep the ones that were obsoleted
only this year or last year.
NEWS:
Announce the changes.
tests/debugger/io_tab_goto.m:
tests/debugger/tabled_read.m:
tests/declarative_debugger/io_stream_test.m:
tests/declarative_debugger/tabled_read_decl.m:
tests/declarative_debugger/tabled_read_decl_goto.m:
tests/general/array_test.m:
tests/hard_coded/mutable_init_impure.m:
tests/hard_coded/remove_file.m:
tests/tabling/mercury_java_parser_dead_proc_elim_bug.m:
tests/tabling/mercury_java_parser_dead_proc_elim_bug2.m:
tests/valid/mercury_java_parser_follow_code_bug.m:
Replace references to predicates and functions that this diff deletes
with their suggested replacements.
In several test cases, bring the programming style up to date.
tests/hard_coded/shift_test.{m,exp}:
Most of this test case tested the now-deleted legacy shift operations.
Replace these with tests of their non-legacy versions, including
testing for the expected exceptions.
tests/hard_coded/shift_test.{m,exp}:
Don't pass --no-warn-obsolete when compiling shift_test.m anymore.
146 lines
3.7 KiB
Mathematica
146 lines
3.7 KiB
Mathematica
%---------------------------------------------------------------------------%
|
|
% vim: ts=4 sw=4 et ft=mercury
|
|
%---------------------------------------------------------------------------%
|
|
|
|
:- module io_tab_goto.
|
|
|
|
:- interface.
|
|
|
|
:- import_module io.
|
|
|
|
:- pred main(io::di, io::uo) is det.
|
|
|
|
:- implementation.
|
|
|
|
:- import_module list.
|
|
:- import_module char.
|
|
:- import_module int.
|
|
|
|
main(!IO) :-
|
|
goto(!IO),
|
|
io_tab_goto.open_input("io_tab_goto.data", Res, Stream, !IO),
|
|
( if Res = 0 then
|
|
io_tab_goto.part_1(Stream, !IO),
|
|
io_tab_goto.part_2(Stream, !IO)
|
|
else
|
|
io.write_string("could not open io_tab_goto.data\n", !IO)
|
|
).
|
|
|
|
:- pred goto(io::di, io::uo) is det.
|
|
|
|
:- pragma no_inline(goto/2).
|
|
|
|
:- pragma foreign_proc(c,
|
|
goto(IO0::di, IO::uo),
|
|
[tabled_for_io, promise_pure],
|
|
"
|
|
printf(""should see this printf\\n"");
|
|
goto label;
|
|
printf(""should never see this printf\\n"");
|
|
label:
|
|
IO = IO0;
|
|
").
|
|
|
|
:- pred io_tab_goto.part_1(c_pointer::in, io::di, io::uo) is det.
|
|
|
|
io_tab_goto.part_1(Stream, !IO) :-
|
|
io_tab_goto.test(Stream, 0, A, !IO),
|
|
io_tab_goto.write_int(A, !IO),
|
|
io_tab_goto.poly_test(Stream, ['a', 'b', 'c'], 0, B, !IO),
|
|
io_tab_goto.write_int(B, !IO).
|
|
|
|
:- pred io_tab_goto.part_2(c_pointer::in, io::di, io::uo) is det.
|
|
|
|
io_tab_goto.part_2(Stream, !IO) :-
|
|
io_tab_goto.test(Stream, 0, A, !IO),
|
|
io_tab_goto.write_int(A, !IO).
|
|
|
|
:- pred test(c_pointer::in, int::in, int::out, io::di, io::uo) is det.
|
|
|
|
test(Stream, SoFar, N, !IO) :-
|
|
io_tab_goto.read_char_code(Stream, CharCode, !IO),
|
|
( if
|
|
char.to_int(Char, CharCode),
|
|
char.is_decimal_digit(Char),
|
|
char.decimal_digit_to_int(Char, CharInt)
|
|
then
|
|
io_tab_goto.test(Stream, SoFar * 10 + CharInt, N, !IO)
|
|
else
|
|
N = SoFar
|
|
).
|
|
|
|
:- pred poly_test(c_pointer::in, T::in, int::in, int::out,
|
|
io::di, io::uo) is det.
|
|
|
|
poly_test(Stream, Unused, SoFar, N, !IO) :-
|
|
io_tab_goto.poly_read_char_code(Stream, Unused, CharCode, !IO),
|
|
( if
|
|
char.to_int(Char, CharCode),
|
|
char.is_decimal_digit(Char),
|
|
char.decimal_digit_to_int(Char, CharInt)
|
|
then
|
|
io_tab_goto.poly_test(Stream, Unused, SoFar * 10 + CharInt, N, !IO)
|
|
else
|
|
N = SoFar
|
|
).
|
|
|
|
:- pragma foreign_decl("C", "#include <stdio.h>").
|
|
|
|
:- pred io_tab_goto.open_input(string::in, int::out, c_pointer::out,
|
|
io::di, io::uo) is det.
|
|
:- pragma no_inline(io_tab_goto.open_input/5).
|
|
|
|
:- pragma foreign_proc("C",
|
|
open_input(FileName::in, Res::out, Stream::out, IO0::di, IO::uo),
|
|
[will_not_call_mercury, promise_pure, tabled_for_io],
|
|
"
|
|
Stream = (MR_Word) fopen((const char *) FileName, ""r"");
|
|
Res = Stream? 0 : -1;
|
|
goto end1;
|
|
end1:
|
|
IO = IO0;
|
|
").
|
|
|
|
:- pred read_char_code(c_pointer::in, int::out,
|
|
io::di, io::uo) is det.
|
|
:- pragma no_inline(io_tab_goto.read_char_code/4).
|
|
|
|
:- pragma foreign_proc("C",
|
|
read_char_code(Stream::in, CharCode::out, IO0::di, IO::uo),
|
|
[will_not_call_mercury, promise_pure, tabled_for_io],
|
|
"
|
|
CharCode = getc((FILE *) Stream);
|
|
goto end2;
|
|
end2:
|
|
IO = IO0;
|
|
").
|
|
|
|
:- pred poly_read_char_code(c_pointer::in, T::in, int::out,
|
|
io::di, io::uo) is det.
|
|
:- pragma no_inline(io_tab_goto.poly_read_char_code/5).
|
|
|
|
:- pragma foreign_proc("C",
|
|
poly_read_char_code(Stream::in, Unused::in, CharCode::out,
|
|
IO0::di, IO::uo),
|
|
[will_not_call_mercury, promise_pure, tabled_for_io],
|
|
"
|
|
/* ignore Unused */
|
|
CharCode = getc((FILE *) Stream);
|
|
goto end3;
|
|
end3:
|
|
IO = IO0;
|
|
").
|
|
|
|
:- pred write_int(int::in, io::di, io::uo) is det.
|
|
:- pragma no_inline(io_tab_goto.write_int/3).
|
|
|
|
:- pragma foreign_proc("C",
|
|
write_int(N::in, IO0::di, IO::uo),
|
|
[will_not_call_mercury, promise_pure],
|
|
"{
|
|
printf(""%d\\n"", (int) N);
|
|
goto end4;
|
|
end4:
|
|
IO = IO0;
|
|
}").
|