--- oup/current/DataAccess/ConnectionManager.pas 2007/02/21 03:12:33 109 +++ oup/current/DataAccess/ConnectionManager.pas 2007/11/25 14:24:53 247 @@ -1,7 +1,7 @@ unit ConnectionManager; interface -uses TypeDefs, DataAccess, Access_OniArchive, Access_OUP_ADB; +uses TypeDefs, DataAccess, Access_OniArchive, Access_OUP_ADB, Access_OniSplitArchive; type TConnections = array of TDataAccess; @@ -34,6 +34,7 @@ type function CloseConnectionByIndex(Index: Integer; var Msg: TStatusMessages): Boolean; overload; function CloseConnection(ID: Integer; var Msg: TStatusMessages): Boolean; overload; function CloseConnection(FileName: String; var Msg: TStatusMessages): Boolean; overload; + function FileOpened(FileName: String): Integer; published end; @@ -153,6 +154,8 @@ begin backend := DB_ADB else if ext = '.DAT' then backend := DB_ONI + else if ext = '.ONI' then + backend := DB_ONISPLIT else begin Msg := SM_UnknownExtension; @@ -166,6 +169,8 @@ begin FConnections[i] := TAccess_OniArchive.Create(FileName, FLastID + 1, CreateMsg); DB_ADB: FConnections[i] := TAccess_OUP_ADB.Create(FileName, FLastID + 1, CreateMsg); + DB_ONISPLIT: + FConnections[i] := TAccess_OniSplitArchive.Create(FileName, FLastID + 1, CreateMsg); end; if CreateMsg = SM_OK then @@ -177,7 +182,6 @@ begin else begin FConnections[i].Close; - FConnections[i].Free; FConnections[i] := nil; SetLength(FConnections, Length(FConnections) - 1); Msg := CreateMsg; @@ -260,6 +264,21 @@ begin end; +function TConnectionManager.FileOpened(FileName: String): Integer; +var + i: Integer; +begin + Result := -1; + if Length(FConnections) > 0 then + for i := 0 to High(FConnections) do + if FConnections[i].FileName = FileName then + begin + Result := FConnections[i].ConnectionID; + Exit; + end; +end; + + initialization ConManager := TConnectionManager.Create; finalization