mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-16 00:19:29 +02:00

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 -
582 lines
9.6 KiB
ObjectPascal
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.
|