123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 |
- {
- $Id$
- This file is part of the Free Pascal run time library.
- Copyright (c) 1999-2000 by Michael Van Canneyt, member of the
- Free Pascal development team
- TDatabase and related objects implementation
-
- See the file COPYING.FPC, included in this distribution,
- for details about the copyright.
- This program 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.
- **********************************************************************}
- { ---------------------------------------------------------------------
- TDatabase
- ---------------------------------------------------------------------}
- Procedure TDatabase.CheckConnected;
- begin
- If Not Connected Then
- DatabaseError(SNotConnected,Self);
- end;
- Procedure TDatabase.CheckDisConnected;
- begin
- If Connected Then
- DatabaseError(SConnected,Self);
- end;
-
- procedure TDataBase.Loaded;
- begin
- //!! To be implemented.
- end;
- procedure TDataBase.SetConnected (Value : boolean);
- begin
- If Value<>FConnected then
- begin
- If Value then
- DoInternalConnect
- else
- begin
- Closedatasets;
- DoInternalDisConnect;
- end;
- FConnected:=Value;
- end;
- end;
- procedure TDatabase.Notification(AComponent: TComponent; Operation: TOperation);
- begin
- //!! To be implemented.
- end;
- constructor TDatabase.Create(AOwner: TComponent);
- begin
- Inherited Create(AOwner);
- end;
- destructor TDatabase.Destroy;
- begin
- Connected:=False;
- RemoveDatasets;
- FDatasets.Free;
- Inherited Destroy;
- end;
- procedure TDatabase.Close;
- begin
- Connected:=False;
- end;
- procedure TDatabase.CloseDataSets;
- Var I : longint;
- begin
- If Assigned(FDatasets) then
- begin
- For I:=FDatasets.Count-1 downto 0 do
- TDBDataset(FDatasets[i]).Close;
- end;
- end;
- procedure TDatabase.RemoveDataSets;
- Var I : longint;
- begin
- If Assigned(FDatasets) then
- For I:=FDataSets.Count-1 downto 0 do
- TDBDataset(FDataSets[i]).Database:=Nil;
- end;
- procedure TDatabase.Open;
- begin
- Connected:=True;
- end;
- Function TDatabase.GetDataSetCount : Longint;
- begin
- If Assigned(FDatasets) Then
- Result:=FDatasets.Count
- else
- Result:=0;
- end;
- Function TDatabase.GetDataset(Index : longint) : TDBDataset;
- begin
- If Assigned(FDatasets) then
- Result:=TDBDataset(FDatasets[Index])
- else
- DatabaseError(SNoDatasets);
- end;
- procedure TDatabase.RegisterDataset (DS : TDBDataset);
- Var I : longint;
- begin
- I:=FDatasets.IndexOf(DS);
- If I=-1 then
- FDatasets.Add(DS)
- else
- DatabaseErrorFmt(SDatasetRegistered,[DS.Name]);
- end;
- procedure TDatabase.UnRegisterDataset (DS : TDBDataset);
- Var I : longint;
- begin
- I:=FDatasets.IndexOf(DS);
- If I<>-1 then
- FDatasets.Delete(I)
- else
- DatabaseErrorFmt(SNoDatasetRegistered,[DS.Name]);
- end;
- { ---------------------------------------------------------------------
- TDBdataset
- ---------------------------------------------------------------------}
- Procedure TDBDataset.SetDatabase (Value : TDatabase);
- begin
- CheckInactive;
- If Value<>FDatabase then
- begin
- If Assigned(FDatabase) then
- FDatabase.UnregisterDataset(Self);
- If Value<>Nil Then
- Value.RegisterDataset(Self);
- FDatabase:=Value;
- end;
- end;
- {
- $Log$
- Revision 1.2 2000-07-13 11:32:56 michael
- + removed logs
-
- }
|