Files
mercury/tests/hard_coded/string_set_char.m
Zoltan Somogyi 33eb3028f5 Clean up the tests in half the test directories.
tests/accumulator/*.m:
tests/analysis_*/*.m:
tests/benchmarks*/*.m:
tests/debugger*/*.{m,exp,inp}:
tests/declarative_debugger*/*.{m,exp,inp}:
tests/dppd*/*.m:
tests/exceptions*/*.m:
tests/general*/*.m:
tests/grade_subdirs*/*.m:
tests/hard_coded*/*.m:
    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 debugger tests,
    specify the new line numbers in .inp files and expect them in .exp files.
2015-02-14 20:14:03 +11:00

129 lines
3.7 KiB
Mathematica

%---------------------------------------------------------------------------%
% vim: ts=4 sw=4 et ft=mercury
%---------------------------------------------------------------------------%
:- module string_set_char.
:- interface.
:- import_module io.
:- pred main(io::di, io::uo) is det.
%---------------------------------------------------------------------------%
%---------------------------------------------------------------------------%
:- implementation.
:- import_module char.
:- import_module require.
:- import_module string.
%---------------------------------------------------------------------------%
main(!IO) :-
( string.set_char('x', -1, "", _) ->
error("test failed")
;
true
),
( string.set_char('x', 0, "", _) ->
error("test failed")
;
true
),
( string.set_char('x', 1, "", _) ->
error("test failed")
;
true
),
( string.set_char('m', 0, "cat", "mat") ->
true
;
error("test failed")
),
( string.set_char('u', 1, "cat", "cut") ->
true
;
error("test failed")
),
( string.set_char('b', 2, "cat", "cab") ->
true
;
error("test failed")
),
( string.set_char('x', 3, "cat", _) ->
error("test failed")
;
true
),
% Test variable-width characters.
% In UTF-8:
% y 1 code unit
% ý 2 code units
% 3 code units
% U+10000 4 code units
(
set_char_by_cp(".aßξ啕𐀀.", 1, 'y', ".yßξ啕𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 1, 'ý', ".ýßξ啕𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 1, '', ".ẏßξ啕𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 1, '𐀀', ".𐀀ßξ啕𐀀.")
->
true
;
io.write_string("variable-width set_char failed (1)\n", !IO)
),
(
set_char_by_cp(".aßξ啕𐀀.", 2, 'y', ".ayξ啕𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 2, 'ý', ".aýξ啕𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 2, '', ".aẏξ啕𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 2, '𐀀', ".a𐀀ξ啕𐀀.")
->
true
;
io.write_string("variable-width set_char failed (2)\n", !IO)
),
(
set_char_by_cp(".aßξ啕𐀀.", 3, 'y', ".aßy啕𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 3, 'ý', ".aßý啕𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 3, '', ".aßẏ啕𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 3, '𐀀', ".aß𐀀啕𐀀.")
->
true
;
io.write_string("variable-width set_char failed (3)\n", !IO)
),
(
set_char_by_cp(".aßξ啕𐀀.", 4, 'y', ".aßξy𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 4, 'ý', ".aßξý𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 4, '', ".aßξẏ𐀀."),
set_char_by_cp(".aßξ啕𐀀.", 4, '𐀀', ".aßξ𐀀𐀀.")
->
true
;
io.write_string("variable-width set_char failed (4)\n", !IO)
),
(
set_char_by_cp(".aßξ啕𐀀.", 5, 'y', ".aßξ啕y."),
set_char_by_cp(".aßξ啕𐀀.", 5, 'ý', ".aßξ啕ý."),
set_char_by_cp(".aßξ啕𐀀.", 5, '', ".aßξ啕ẏ."),
set_char_by_cp(".aßξ啕𐀀.", 5, '𐀀', ".aßξ啕𐀀.")
->
true
;
io.write_string("variable-width set_char failed (5)\n", !IO)
),
io.write_string("test finished\n", !IO).
:- pred set_char_by_cp(string::in, int::in, char::in, string::out) is semidet.
set_char_by_cp(Str0, CodePoint, Char, Str) :-
string.codepoint_offset(Str0, CodePoint, Offset),
string.set_char(Char, Offset, Str0, Str),
trace [io(!IO), runtime(env("DEBUG"))] (
io.write_string(Str, !IO),
nl(!IO)
).