Files
mercury/tests/hard_coded/string_prev_index_ilseq.m
Peter Wang 0c9bdf2587 Define behaviour of string.prev_index on ill-formed sequences.
library/string.m:
    Make string.prev_index and string.unsafe_prev_index
    return either U+FFFD or an unpaired surrogate code point
    when an ill-formed code unit sequence is detected.

tests/hard_coded/Mmakefile:
tests/hard_coded/string_prev_index_ilseq.exp:
tests/hard_coded/string_prev_index_ilseq.exp2:
tests/hard_coded/string_prev_index_ilseq.m:
    Add test case.
2019-10-24 09:14:46 +11:00

45 lines
1.3 KiB
Mathematica

%---------------------------------------------------------------------------%
% vim: ts=4 sw=4 et ft=mercury
%---------------------------------------------------------------------------%
%
% The .exp file is for backends using UTF-8 string encoding.
% The .exp2 file is for backends using UTF-16 string encoding.
%
%---------------------------------------------------------------------------%
:- module string_prev_index_ilseq.
:- interface.
:- import_module io.
:- pred main(io::di, io::uo) is det.
%---------------------------------------------------------------------------%
:- implementation.
:- import_module char.
:- import_module list.
:- import_module string.
%---------------------------------------------------------------------------%
main(!IO) :-
S0 = "😀",
S1 = string.between(S0, 0, 1),
S2 = string.between(S0, 1, 2),
S = S0 ++ S2 ++ S1 ++ S0,
test_prev_index(S, count_code_units(S), !IO).
:- pred test_prev_index(string::in, int::in, io::di, io::uo) is det.
test_prev_index(S, Index, !IO) :-
( if string.prev_index(S, Index, PrevIndex, Char) then
io.format("string.prev_index(S, %d, %d, %#x)\n",
[i(Index), i(PrevIndex), i(char.to_int(Char))], !IO),
test_prev_index(S, PrevIndex, !IO)
else
io.format("string.prev_index(S, %d, _, _) failed\n",
[i(Index)], !IO)
).