fpc/tests/webtbs/tw16004.pp
florian edaa0b3014 * changing tests to fix regressions is only the last resort, so this should be sorted out by other means, r19116 reverted
--- Reverse-merging r19116 into '.':
U    tests\webtbs\tw4675.pp
U    tests\webtbs\tw7758.pp
U    tests\webtbs\tw18702.pp
U    tests\webtbs\tw3595.pp
U    tests\webtbs\tw5001.pp
U    tests\webtbs\tw2250.pp
U    tests\webtbs\tw3492.pp
U    tests\webtbs\tw16004.pp
 G   .
--- Recording mergeinfo for reverse merge of r19116 into '.':
 G   .

git-svn-id: trunk@19135 -
2011-09-17 18:19:47 +00:00

43 lines
1.3 KiB
ObjectPascal

{$apptype console}
{$mode Delphi}
{$assertions on}
{$codepage cp1251}
function verify(const p; const size: integer; const z: array of byte): boolean;
begin
assert( size = length(z)*sizeof(z[0]) );
result := CompareByte(p, z[0], size) = 0;
writeln(result)
end;
procedure foo;
var a: array[0..5] of char = 'willow';
const b: array[0..2] of WideChar = 'èâà';
begin
assert( verify(a, sizeof(a), [ord('w'), ord('i'), ord('l'), ord('l'), ord('o'), ord('w')]) );
{$ifdef endian_big}
assert( verify(b, sizeof(b), [$04,$38,$04,$32,$04,$30]) )
{$else}
assert( verify(b, sizeof(b), [$38,$04,$32,$04,$30,$04]) )
{$endif}
end;
const c: array[0..10] of char = 'rosenberg';
var d: array[0..10] of WideChar = 'ðîçåíáåðã';
z: array[0..1] of WideChar = 'û';
x: array[0..0] of char = 'x';
begin
assert( verify(c, sizeof(c), [114, 111, 115, 101, 110, 98, 101, 114, 103, 0, 0]) );
{$ifdef endian_big}
assert( verify(d, sizeof(d), [$04,$40,$04,$3E,$04,$37,$04,$35,$04,$3D,$04,$31,$04,$35,$04,$40,$04,$33,0,0,0,0]) );
{$else}
assert( verify(d, sizeof(d), [$40,$04,$3E,$04,$37,$04,$35,$04,$3D,$04,$31,$04,$35,$04,$40,$04,$33,$04,0,0,0,0]) );
{$endif}
foo;
{$ifdef endian_big}
assert( verify(z, sizeof(z), [$04,$4B,0,0]) );
{$else}
assert( verify(z, sizeof(z), [$4B,$04,0,0]) );
{$endif}
assert( verify(x, sizeof(x), [120]) )
end.