~ubuntu-branches/ubuntu/saucy/lazarus/saucy

« back to all changes in this revision

Viewing changes to components/lazutils/lazmethodlist.pas

  • Committer: Package Import Robot
  • Author(s): Paul Gevers, Abou Al Montacir, Bart Martens, Paul Gevers
  • Date: 2013-06-08 14:12:17 UTC
  • mfrom: (1.1.9)
  • Revision ID: package-import@ubuntu.com-20130608141217-7k0cy9id8ifcnutc
Tags: 1.0.8+dfsg-1
[ Abou Al Montacir ]
* New upstream major release and multiple maintenace release offering many
  fixes and new features marking a new milestone for the Lazarus development
  and its stability level.
  - The detailed list of changes can be found here:
    http://wiki.lazarus.freepascal.org/Lazarus_1.0_release_notes
    http://wiki.lazarus.freepascal.org/Lazarus_1.0_fixes_branch
* LCL changes:
  - LCL is now a normal package.
      + Platform independent parts of the LCL are now in the package LCLBase
      + LCL is automatically recompiled when switching the target platform,
        unless pre-compiled binaries for this target are already installed.
      + No impact on existing projects.
      + Linker options needed by LCL are no more added to projects that do
        not use the LCL package.
  - Minor changes in LCL basic classes behaviour
      + TCustomForm.Create raises an exception if a form resource is not
        found.
      + TNotebook and TPage: a new implementation of these classes was added.
      + TDBNavigator: It is now possible to have focusable buttons by setting
        Options = [navFocusableButtons] and TabStop = True, useful for
        accessibility and for devices with neither mouse nor touch screen.
      + Names of TControlBorderSpacing.GetSideSpace and GetSpace were swapped
        and are now consistent. GetSideSpace = Around + GetSpace.
      + TForm.WindowState=wsFullscreen was added
      + TCanvas.TextFitInfo was added to calculate how many characters will
        fit into a specified Width. Useful for word-wrapping calculations.
      + TControl.GetColorResolvingParent and
        TControl.GetRGBColorResolvingParent were added, simplifying the work
        to obtain the final color of the control while resolving clDefault
        and the ParentColor.
      + LCLIntf.GetTextExtentExPoint now has a good default implementation
        which works in any platform not providing a specific implementation.
        However, Widgetset specific implementation is better, when available.
      + TTabControl was reorganized. Now it has the correct class hierarchy
        and inherits from TCustomTabControl as it should.
  - New unit in the LCL:
      + lazdialogs.pas: adds non-native versions of various native dialogs,
        for example TLazOpenDialog, TLazSaveDialog, TLazSelectDirectoryDialog.
        It is used by widgetsets which either do not have a native dialog, or
        do not wish to use it because it is limited. These dialogs can also be
        used by user applications directly.
      + lazdeviceapis.pas: offers an interface to more hardware devices such
        as the accelerometer, GPS, etc. See LazDeviceAPIs
      + lazcanvas.pas: provides a TFPImageCanvas descendent implementing
        drawing in a LCL-compatible way, but 100% in Pascal.
      + lazregions.pas. LazRegions is a wholly Pascal implementation of
        regions for canvas clipping, event clipping, finding in which control
        of a region tree one an event should reach, for drawing polygons, etc.
      + customdrawncontrols.pas, customdrawndrawers.pas,
        customdrawn_common.pas, customdrawn_android.pas and
        customdrawn_winxp.pas: are the Lazarus Custom Drawn Controls -controls
        which imitate the standard LCL ones, but with the difference that they
        are non-native and support skinning.
  - New APIs added to the LCL to improve support of accessibility software
    such as screen readers.
* IDE changes:
  - Many improvments.
  - The detailed list of changes can be found here:
    http://wiki.lazarus.freepascal.org/New_IDE_features_since#v1.0_.282012-08-29.29
    http://wiki.lazarus.freepascal.org/Lazarus_1.0_release_notes#IDE_Changes
* Debugger / Editor changes:
  - Added pascal sources and breakpoints to the disassembler
  - Added threads dialog.
* Components changes:
  - TAChart: many fixes and new features
  - CodeTool: support Delphi style generics and new syntax extensions.
  - AggPas: removed to honor free licencing. (Closes: Bug#708695)
[Bart Martens]
* New debian/watch file fixing issues with upstream RC release.
[Abou Al Montacir]
* Avoid changing files in .pc hidden directory, these are used by quilt for
  internal purpose and could lead to surprises during build.
[Paul Gevers]
* Updated get-orig-source target and it compinion script orig-tar.sh so that they
  repack the source file, allowing bug 708695 to be fixed.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
unit LazMethodList;
 
2
 
 
3
{$mode objfpc}{$H+}
 
4
 
 
5
interface
 
6
 
 
7
uses
 
8
  Classes, SysUtils; 
 
9
 
 
10
type
 
11
  { TMethodList - array of TMethod }
 
12
 
 
13
  TMethodList = class
 
14
  private
 
15
    FItems: ^TMethod;
 
16
    FCount: integer;
 
17
    function GetItems(Index: integer): TMethod;
 
18
    procedure SetItems(Index: integer; const AValue: TMethod);
 
19
  public
 
20
    destructor Destroy; override;
 
21
    function Count: integer;
 
22
    function NextDownIndex(var Index: integer): boolean;
 
23
    function IndexOf(const AMethod: TMethod): integer;
 
24
    procedure Delete(Index: integer);
 
25
    procedure Remove(const AMethod: TMethod);
 
26
    procedure Add(const AMethod: TMethod);
 
27
    procedure Add(const AMethod: TMethod; AsLast: boolean);
 
28
    procedure Insert(Index: integer; const AMethod: TMethod);
 
29
    procedure Move(OldIndex, NewIndex: integer);
 
30
    procedure RemoveAllMethodsOfObject(const AnObject: TObject);
 
31
    procedure CallNotifyEvents(Sender: TObject);
 
32
  public
 
33
    property Items[Index: integer]: TMethod read GetItems write SetItems; default;
 
34
  end;
 
35
 
 
36
implementation
 
37
 
 
38
{ TMethodList }
 
39
 
 
40
function TMethodList.GetItems(Index: integer): TMethod;
 
41
begin
 
42
  Result:=FItems[Index];
 
43
end;
 
44
 
 
45
procedure TMethodList.SetItems(Index: integer; const AValue: TMethod);
 
46
begin
 
47
  FItems[Index]:=AValue;
 
48
end;
 
49
 
 
50
destructor TMethodList.Destroy;
 
51
begin
 
52
  ReAllocMem(FItems,0);
 
53
  inherited Destroy;
 
54
end;
 
55
 
 
56
function TMethodList.Count: integer;
 
57
begin
 
58
  if Self<>nil then
 
59
    Result:=FCount
 
60
  else
 
61
    Result:=0;
 
62
end;
 
63
 
 
64
function TMethodList.NextDownIndex(var Index: integer): boolean;
 
65
begin
 
66
  if Self<>nil then begin
 
67
    dec(Index);
 
68
    if (Index>=FCount) then
 
69
      Index:=FCount-1;
 
70
  end else
 
71
    Index:=-1;
 
72
  Result:=(Index>=0);
 
73
end;
 
74
 
 
75
function TMethodList.IndexOf(const AMethod: TMethod): integer;
 
76
begin
 
77
  if Self<>nil then begin
 
78
    Result:=FCount-1;
 
79
    while Result>=0 do begin
 
80
      if (FItems[Result].Code=AMethod.Code)
 
81
      and (FItems[Result].Data=AMethod.Data) then exit;
 
82
      dec(Result);
 
83
    end;
 
84
  end else
 
85
    Result:=-1;
 
86
end;
 
87
 
 
88
procedure TMethodList.Delete(Index: integer);
 
89
begin
 
90
  dec(FCount);
 
91
  if FCount>Index then
 
92
    System.Move(FItems[Index+1],FItems[Index],(FCount-Index)*SizeOf(TMethod));
 
93
  ReAllocMem(FItems,FCount*SizeOf(TMethod));
 
94
end;
 
95
 
 
96
procedure TMethodList.Remove(const AMethod: TMethod);
 
97
var
 
98
  i: integer;
 
99
begin
 
100
  if Self<>nil then begin
 
101
    i:=IndexOf(AMethod);
 
102
    if i>=0 then Delete(i);
 
103
  end;
 
104
end;
 
105
 
 
106
procedure TMethodList.Add(const AMethod: TMethod);
 
107
begin
 
108
  inc(FCount);
 
109
  ReAllocMem(FItems,FCount*SizeOf(TMethod));
 
110
  FItems[FCount-1]:=AMethod;
 
111
end;
 
112
 
 
113
procedure TMethodList.Add(const AMethod: TMethod; AsLast: boolean);
 
114
begin
 
115
  if AsLast then
 
116
    Add(AMethod)
 
117
  else
 
118
    Insert(0,AMethod);
 
119
end;
 
120
 
 
121
procedure TMethodList.Insert(Index: integer; const AMethod: TMethod);
 
122
begin
 
123
  inc(FCount);
 
124
  ReAllocMem(FItems,FCount*SizeOf(TMethod));
 
125
  if Index<FCount then
 
126
    System.Move(FItems[Index],FItems[Index+1],(FCount-Index-1)*SizeOf(TMethod));
 
127
  FItems[Index]:=AMethod;
 
128
end;
 
129
 
 
130
procedure TMethodList.Move(OldIndex, NewIndex: integer);
 
131
var
 
132
  MovingMethod: TMethod;
 
133
begin
 
134
  if OldIndex=NewIndex then exit;
 
135
  MovingMethod:=FItems[OldIndex];
 
136
  if OldIndex>NewIndex then
 
137
    System.Move(FItems[NewIndex],FItems[NewIndex+1],
 
138
                SizeOf(TMethod)*(OldIndex-NewIndex))
 
139
  else
 
140
    System.Move(FItems[NewIndex+1],FItems[NewIndex],
 
141
                SizeOf(TMethod)*(NewIndex-OldIndex));
 
142
  FItems[NewIndex]:=MovingMethod;
 
143
end;
 
144
 
 
145
procedure TMethodList.RemoveAllMethodsOfObject(const AnObject: TObject);
 
146
var
 
147
  i: Integer;
 
148
begin
 
149
  if Self=nil then exit;
 
150
  i:=FCount-1;
 
151
  while i>=0 do begin
 
152
    if TObject(FItems[i].Data)=AnObject then Delete(i);
 
153
    dec(i);
 
154
  end;
 
155
end;
 
156
 
 
157
procedure TMethodList.CallNotifyEvents(Sender: TObject);
 
158
var
 
159
  i: LongInt;
 
160
begin
 
161
  i:=Count;
 
162
  while NextDownIndex(i) do
 
163
    TNotifyEvent(Items[i])(Sender);
 
164
end;
 
165
 
 
166
end.
 
167