summaryrefslogtreecommitdiff
path: root/fpcsrc/tests/test/tcmp.pp
blob: 7076513e93df4b04c477f6cddce74b226fbdb066 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
const
  err: boolean = false;

var
  a, b: array[0..512] of byte;

procedure test_compare;
type
  pdword = ^cardinal;
var
  i, j, k: longint;
  l: longint;
begin
  for i := 0 to 512 do
    a[i] := byte(i);
  for i := 0 to 256 do
    for j := 0 to 31 do
      for k := 0 to 31 do
        begin
          fillchar(b,sizeof(b),0);
          move(a[j],b[k+4],i);
          if comparebyte(a[j],b[k+4],i)<>0 then
            begin
              writeln('cmpbyte error 1 for (',i,',',j,',',k,')');
              halt(1);
            end;
          if comparebyte(a[j],b[k+4],i+1)<0 then
            begin
              writeln(a[j+i],' ',b[k+4+i]);
              writeln('cmpbyte error 2 for (',i,',',j,',',k,')');
              halt(2);
            end;
          if comparebyte(b[k+4],a[j],i+1)>0 then
            begin
              writeln(b[k+4+i],' ',a[j+i]);
              writeln('cmpbyte error 3 for (',i,',',j,',',k,')');
              halt(3);
            end;

          if (i and 1 = 0) then
            begin
              if compareword(a[j],b[k+4],i shr 1)<>0 then
                begin
                  writeln('cmpword error 4 for (',i,',',j,',',k,')');
                  halt(4);
                end;
              if compareword(a[j],b[k+4],i shr 1 + 1)<0 then
                begin
                  writeln('cmpword error 5 for (',i,',',j,',',k,')');
                  halt(5);
                end;
              if compareword(b[k+4],a[j],i shr 1 + 1)>0 then
                begin
                  writeln('cmpword error 6 for (',i,',',j,',',k,')');
                  halt(6);
                end;
            end
          else
            begin
              if compareword(a[j],b[k+4],(i+1) shr 1)<0 then
                begin
                  writeln('cmpword error 7 for (',i,',',j,',',k,')');
                  halt(7);
                end;
              if compareword(b[k+4],a[j],(i+1) shr 1)>0 then
                begin
                  writeln('cmpword error 8 for (',i,',',j,',',k,')');
                  halt(8);
                end;
            end;

          if (i and 3 = 0) then
            begin
              if comparedword(a[j],b[k+4],i shr 2)<>0 then
                begin
                  writeln('cmpdword error 9 for (',i,',',j,',',k,')');
                  halt(9);
                end;
              if comparedword(a[j],b[k+4],i shr 2 + 1)<=0 then
                begin
                  writeln(comparedword(a[j],b[k+4],i shr 2+1));
                  writeln(unaligned(pdword(@a[j])^),' ',unaligned(pdword(@b[k+4])^));
                  writeln(unaligned(pdword(@a[j+i])^),' ',unaligned(pdword(@b[k+4+i])^));
                  writeln(unaligned(pdword(@a[j+i+4])^),' ',unaligned(pdword(@b[k+4+i+4])^));
                  writeln('cmpdword error 10 for (',i,',',j,',',k,')');
                  halt(10);
                end;
              if comparedword(b[k+4],a[j],i shr 2 + 1)>=0 then
                begin
                  writeln(comparedword(b[k+4],a[j],i shr 2+1));
                  writeln(unaligned(pdword(@b[k+4])^),' ',unaligned(pdword(@a[j])^));
                  writeln(unaligned(pdword(@b[k+4+i])^),' ',unaligned(pdword(@a[j+i])^));
                  writeln(unaligned(pdword(@b[k+4+i+4])^),' ',unaligned(pdword(@a[j+i+4])^));
                  writeln('cmpdword error 11 for (',i,',',j,',',k,')');
                  halt(11);
                end;
            end
          else
            begin
              if comparedword(a[j],b[k+4],(i+3) shr 2)<0 then
                begin
                  writeln(comparedword(a[j],b[k+4],(i+3) shr 2));
                  writeln(unaligned(pdword(@a[j])^),' ',unaligned(pdword(@b[k+4])^));
                  writeln(unaligned(pdword(@a[j+(i+3) shr 2-1])^),' ',unaligned(pdword(@b[k+4+(i+3) shr 2-1])^));
                  writeln('cmpdword error 12 for (',i,',',j,',',k,')');
                  halt(12);
                end;
              if comparedword(b[k+4],a[j],(i+3) shr 2)>0 then
                begin
                  writeln(comparedword(b[k+4],a[j],(i+3) shr 2));
                  writeln(unaligned(pdword(@b[k+4])^),' ',unaligned(pdword(@a[j])^));
                  writeln(unaligned(pdword(@b[k+4+(i+3) shr 2-1])^),' ',unaligned(pdword(@a[j+(i+3) shr 2-1])^));
                  writeln('cmpdword error 13 for (',i,',',j,',',k,')');
                  halt(13);
                end;
            end;
        end;
end;


begin
  test_compare;
end.