t_id
204
t_adddate
2003/10/03
t_result
0
t_knownrunerror
0
tr_id | run | tr_ok | tr_skip | tr_result |
---|---|---|---|---|
526257215 | 948326 | True | False | Successfully run |
Record count: 1
{$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(,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,s); if sizeof(extended) = 10 then check('-1.123450000000000E+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( ,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,s); if sizeof(extended) = 10 then check('-1.123450000000000E+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( ,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,s); if sizeof(extended) = 10 then check('-1.123450000000000E+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.