fpc/tests/test/jvm/tstr.pp
Jonas Maebe d4b6406e62 * fixed compilation of new str<->float code on the JVM target (patch by
Max Nazhalov) and use that code by default on the JVM target
  * adapted JVM tests for the new str<->float code similar to how the
    generic tests were adapted

git-svn-id: trunk@25954 -
2013-11-06 16:13:50 +00:00

582 lines
9.6 KiB
ObjectPascal

program tstr;
uses
{$ifdef java}jdk15{$else}androidr14{$endif};
{$macro on}
{$define write:=JLSystem.fout.print}
{$define writeln:=JLSystem.fout.println}
{$ifdef fpc}
{$ifndef ver1_0}
{$define haswidestring}
{$endif}
{$else}
{$ifndef ver70}
{$define haswidestring}
{$endif}
{$endif}
procedure test_shortstr;
type
tlocalstring = shortstring;
var
l: longint;
c: cardinal;
f: real;
i: int64;
q: qword;
s: tlocalstring;
len: byte;
frac: word;
longval : longint;
procedure check(const ss: tlocalstring);
begin
if s <> ss then
begin
writeln('error!');
halt(1);
end;
end;
begin
writeln('testing str(<value>,shortstring)...');
l := -1;
str(l,s);
check('-1');
str(l:0,s);
check('-1');
str(l:1,s);
check('-1');
str(l:2,s);
check('-1');
str(l:3,s);
check(' -1');
len := 4;
str(l:len,s);
check(' -1');
c := 10;
str(c,s);
check('10');
str(c:0,s);
check('10');
str(c:1,s);
check('10');
str(c:2,s);
check('10');
str(c:3,s);
check(' 10');
{ for more in-depth tests of str_real, see ../tstreal[1,2].pp }
f := -1.12345;
{$IFOPT E-}
str(f:22,s);
if (sizeof(extended) = 10) or
(sizeof(extended) = 12) then
check('-1.12345000000000E+000')
else if sizeof(extended) = 8 then
check('-1.12345000000000E+000')
else
check('error, not yet implemented!!!!');
{$endif}
{ the number of exponents depends on the maaping of the real type }
if sizeof(real) = 8 then
begin
str(f:0,s);
check('-1.1E+000');
str(f:1,s);
check('-1.1E+000');
str(f:2,s);
check('-1.1E+000');
str(f:3,s);
check('-1.1E+000');
str(f:4,s);
check('-1.1E+000');
end
else
begin
str(f:0,s);
check('-1.1E+00');
str(f:1,s);
check('-1.1E+00');
str(f:2,s);
check('-1.1E+00');
str(f:3,s);
check('-1.1E+00');
str(f:4,s);
check('-1.1E+00');
end;
str(f:0:0,s);
check('-1');
str(f:0:1,s);
check('-1.1');
str(f:0:2,s);
check('-1.12');
str(f:1:0,s);
check('-1');
str(f:1:1,s);
check('-1.1');
str(f:5:0,s);
check(' -1');
str(f:5:1,s);
check(' -1.1');
str(f:5:2,s);
check('-1.12');
len := 6;
frac := 2;
str(f:len:frac,s);
check(' -1.12');
i := -1;
str(i,s);
check('-1');
str(i:0,s);
check('-1');
str(i:1,s);
check('-1');
str(i:2,s);
check('-1');
str(i:3,s);
check(' -1');
i:=655536;
str(i,s);
check('655536');
str(i:0,s);
check('655536');
str(i:1,s);
check('655536');
str(i:2,s);
check('655536');
str(i:3,s);
check('655536');
longval:=1;
i:=int64(longval) shl 33;
str(i,s);
check('8589934592');
str(i:0,s);
check('8589934592');
str(i:1,s);
check('8589934592');
str(i:2,s);
check('8589934592');
str(i:3,s);
check('8589934592');
q := 10;
str(q,s);
check('10');
str(q:0,s);
check('10');
str(q:1,s);
check('10');
str(q:2,s);
check('10');
str(q:3,s);
check(' 10');
q:=655536;
str(q,s);
check('655536');
str(q:0,s);
check('655536');
str(q:1,s);
check('655536');
str(q:2,s);
check('655536');
str(q:3,s);
check('655536');
longval:=1;
q:=qword(longval) shl 33;
str(q,s);
check('8589934592');
str(q:0,s);
check('8589934592');
str(q:1,s);
check('8589934592');
str(q:2,s);
check('8589934592');
str(q:3,s);
check('8589934592');
end;
procedure test_ansistr;
type
tlocalstring = ansistring;
var
l: longint;
c: cardinal;
f: real;
i: int64;
q: qword;
s: tlocalstring;
len: shortint;
frac: smallint;
longval : longint;
procedure check(const ss: tlocalstring);
begin
if s <> ss then
begin
writeln('error!');
halt(1);
end;
end;
begin
writeln('testing str(<value>,ansistring)...');
l := -1;
str(l,s);
check('-1');
str(l:0,s);
check('-1');
str(l:1,s);
check('-1');
str(l:2,s);
check('-1');
str(l:3,s);
check(' -1');
len := 4;
str(l:len,s);
check(' -1');
c := 10;
str(c,s);
check('10');
str(c:0,s);
check('10');
str(c:1,s);
check('10');
str(c:2,s);
check('10');
str(c:3,s);
check(' 10');
{ for more in-depth tests of str_real, see ../tstreal[1,2].pp }
f := -1.12345;
{$IFOPT E-}
str(f:22,s);
if (sizeof(extended) = 10) or
(sizeof(extended) = 12) then
check('-1.12345000000000E+000')
else if sizeof(extended) = 8 then
check('-1.12345000000000E+000')
else
check('error, not yet implemented!!!!');
{$endif}
{ the number of exponents depends on the maaping of the real type }
if sizeof(real) = 8 then
begin
str(f:0,s);
check('-1.1E+000');
str(f:1,s);
check('-1.1E+000');
str(f:2,s);
check('-1.1E+000');
str(f:3,s);
check('-1.1E+000');
str(f:4,s);
check('-1.1E+000');
end
else
begin
str(f:0,s);
check('-1.1E+00');
str(f:1,s);
check('-1.1E+00');
str(f:2,s);
check('-1.1E+00');
str(f:3,s);
check('-1.1E+00');
str(f:4,s);
check('-1.1E+00');
end;
str(f:0:0,s);
check('-1');
str(f:0:1,s);
check('-1.1');
str(f:0:2,s);
check('-1.12');
str(f:1:0,s);
check('-1');
str(f:1:1,s);
check('-1.1');
str(f:5:0,s);
check(' -1');
str(f:5:1,s);
check(' -1.1');
str(f:5:2,s);
check('-1.12');
len := 6;
frac := 2;
str(f:len:frac,s);
check(' -1.12');
i := -1;
str(i,s);
check('-1');
str(i:0,s);
check('-1');
str(i:1,s);
check('-1');
str(i:2,s);
check('-1');
str(i:3,s);
check(' -1');
i:=655536;
str(i,s);
check('655536');
str(i:0,s);
check('655536');
str(i:1,s);
check('655536');
str(i:2,s);
check('655536');
str(i:3,s);
check('655536');
longval:=1;
i:=int64(longval) shl 33;
str(i,s);
check('8589934592');
str(i:0,s);
check('8589934592');
str(i:1,s);
check('8589934592');
str(i:2,s);
check('8589934592');
str(i:3,s);
check('8589934592');
q := 10;
str(q,s);
check('10');
str(q:0,s);
check('10');
str(q:1,s);
check('10');
str(q:2,s);
check('10');
str(q:3,s);
check(' 10');
q:=655536;
str(q,s);
check('655536');
str(q:0,s);
check('655536');
str(q:1,s);
check('655536');
str(q:2,s);
check('655536');
str(q:3,s);
check('655536');
longval:=1;
q:=qword(longval) shl 33;
str(q,s);
check('8589934592');
str(q:0,s);
check('8589934592');
str(q:1,s);
check('8589934592');
str(q:2,s);
check('8589934592');
str(q:3,s);
check('8589934592');
end;
{$ifdef haswidestring}
procedure test_widestr;
type
tlocalstring = widestring;
var
l: longint;
c: cardinal;
f: real;
i: int64;
q: qword;
s: tlocalstring;
len: longint;
frac: cardinal;
longval : longint;
procedure check(const ss: tlocalstring);
begin
if s <> ss then
begin
writeln('error!');
halt(1);
end;
end;
begin
writeln('testing str(<value>,widestring)...');
l := -1;
str(l,s);
check('-1');
str(l:0,s);
check('-1');
str(l:1,s);
check('-1');
str(l:2,s);
check('-1');
str(l:3,s);
check(' -1');
len := 4;
str(l:len,s);
check(' -1');
c := 10;
str(c,s);
check('10');
str(c:0,s);
check('10');
str(c:1,s);
check('10');
str(c:2,s);
check('10');
str(c:3,s);
check(' 10');
{ for more in-depth tests of str_real, see ../tstreal[1,2].pp }
f := -1.12345;
{$IFOPT E-}
str(f:22,s);
if sizeof(extended) = 10 then
check('-1.12345000000000E+000')
else if sizeof(extended) = 8 then
check('-1.12345000000000E+000')
else
check('error, not yet implemented!!!!');
{$endif}
{ the number of exponents depends on the maaping of the real type }
if sizeof(real) = 8 then
begin
str(f:0,s);
check('-1.1E+000');
str(f:1,s);
check('-1.1E+000');
str(f:2,s);
check('-1.1E+000');
str(f:3,s);
check('-1.1E+000');
str(f:4,s);
check('-1.1E+000');
end
else
begin
str(f:0,s);
check('-1.1E+00');
str(f:1,s);
check('-1.1E+00');
str(f:2,s);
check('-1.1E+00');
str(f:3,s);
check('-1.1E+00');
str(f:4,s);
check('-1.1E+00');
end;
str(f:0:0,s);
check('-1');
str(f:0:1,s);
check('-1.1');
str(f:0:2,s);
check('-1.12');
str(f:1:0,s);
check('-1');
str(f:1:1,s);
check('-1.1');
str(f:5:0,s);
check(' -1');
str(f:5:1,s);
check(' -1.1');
str(f:5:2,s);
check('-1.12');
len := 6;
frac := 2;
str(f:len:frac,s);
check(' -1.12');
i := -1;
str(i,s);
check('-1');
str(i:0,s);
check('-1');
str(i:1,s);
check('-1');
str(i:2,s);
check('-1');
str(i:3,s);
check(' -1');
i:=655536;
str(i,s);
check('655536');
str(i:0,s);
check('655536');
str(i:1,s);
check('655536');
str(i:2,s);
check('655536');
str(i:3,s);
check('655536');
longval:=1;
i:=int64(longval) shl 33;
str(i,s);
check('8589934592');
str(i:0,s);
check('8589934592');
str(i:1,s);
check('8589934592');
str(i:2,s);
check('8589934592');
str(i:3,s);
check('8589934592');
q := 10;
str(q,s);
check('10');
str(q:0,s);
check('10');
str(q:1,s);
check('10');
str(q:2,s);
check('10');
str(q:3,s);
check(' 10');
q:=655536;
str(q,s);
check('655536');
str(q:0,s);
check('655536');
str(q:1,s);
check('655536');
str(q:2,s);
check('655536');
str(q:3,s);
check('655536');
longval:=1;
q:=qword(longval) shl 33;
str(q,s);
check('8589934592');
str(q:0,s);
check('8589934592');
str(q:1,s);
check('8589934592');
str(q:2,s);
check('8589934592');
str(q:3,s);
check('8589934592');
end;
{$endif haswidestring}
begin
test_shortstr;
test_ansistr;
{$ifdef haswidestring}
test_widestr;
{$endif haswidestring}
writeln('str tests successful!');
end.