TCollection.AtInsert
Insert an element at a certain position in the collection.
Declaration
Source position: objects.pp line 456
default 
  procedure AtInsert(Index: Sw_Integer; Item: Pointer);
Description
AtInsert inserts Item in the collection at position Index, shifting all elements by one position. In case the current limit is reached, the collection will try to expand with a call to SetLimit
Errors
If Index isn't valid then Error is called with CoIndexError. If the collection fails to expand, then coOverFlow is passed to Error.
See also
| Name | Description | 
|---|---|
| TCollection.Insert | Insert a new item in the collection at the end. | 
Example
Program ex34;
{ Program to demonstrate the TCollection.AtInsert method }
Uses Objects,MyObject; { For TMyObject definition and registration }
Var C : PCollection;
    M : PMyObject;
    I : Longint;
Procedure PrintField (Dummy: Pointer;P : PMyObject);
begin
  Writeln ('Field : ',P^.GetField);
end;
begin
  Randomize;
  C:=New(PCollection,Init(120,10));
  Writeln ('Inserting 100 records at random places.');
  For I:=1 to 100 do
    begin
    M:=New(PMyObject,Init);
    M^.SetField(I-1);
    If I=1 then
      C^.Insert(M)
    else
      With C^ do
        AtInsert(Random(Count),M);
    end;
  Writeln ('Values : ');
  C^.Foreach(@PrintField);
  Dispose(C,Done);
end.