-
Notifications
You must be signed in to change notification settings - Fork 1
/
adtutils_impl.i
78 lines (69 loc) · 2.17 KB
/
adtutils_impl.i
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
{@discard
This file is a part of the PascalAdt library, which provides
commonly used algorithms and data structures for the FPC and Delphi
compilers.
Copyright (C) 2004, 2005, 2006 by Lukasz Czajka
This library is free software; you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as
published by the Free Software Foundation; either version 2.1 of the
License, or (at your option) any later version.
This library is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301
USA }
{@discard
adtutils_impl.i::prefix=&_mcp_prefix&::item_type=&ItemType&
}
&include adtutils.defs
&include adtutils_impl.mcp
procedure ExchangeItem(var item1, item2 : ItemType); &_mcp_inline
var
temp : ItemType;
begin
temp := item1;
item1 := item2;
item2 := temp;
end;
procedure SafeMove(var src, dest : ItemType; num : SizeType);
&if (&ItemType == TObject || &ItemType == Integer || &ItemType == Pointer ||
&ItemType == Cardinal || &ItemType == Real)
begin
system.Move(src, dest, num*SizeOf(ItemType));
end;
&else
var
psrc, pdest : PItemType;
begin
psrc := @src;
pdest := @dest;
if (psrc <> pdest) and (num > 0) then
begin
if (PointerValueType(psrc) < PointerValueType(pdest)) and
(PointerValueType(psrc) + UnsignedType(num)*SizeOf(ItemType) >= PointerValueType(pdest)) then
begin
Inc(pdest, num - 1);
Inc(psrc, num - 1);
while (num > 0) do
begin
pdest^ := psrc^;
Dec(num);
Dec(pdest);
Dec(psrc);
end;
end else
begin
while (num > 0) do
begin
pdest^ := psrc^;
Dec(num);
Inc(pdest);
Inc(psrc);
end;
end;
end;
end;
&endif