--- oup/rewrite/DataAccess/Access_OniArchive.pas 2007/02/20 20:43:29 101 +++ oup/current/DataAccess/Access_OniArchive.pas 2007/02/22 00:37:39 112 @@ -42,7 +42,7 @@ type procedure LoadRawFilePart(FileID, DatOffset, Offset, Size: Integer; var Target: TStream); overload; override; procedure UpdateRawFilePart(FileID, DatOffset, Offset, Size: Integer; Src: TStream); overload; override; - function AppendRawFile(LocSep: Boolean; Size: Integer; Src: TStream): Integer; overload; override; + function AppendRawFile(LocSep: Boolean; Src: TStream): Integer; overload; override; published end; @@ -59,29 +59,6 @@ uses constructor TAccess_OniArchive.Create(DatFilename: String; ConnectionID: Integer; var Msg: TStatusMessages); -type - THeader = packed record - Ident: array[0..$13] of Byte; - Files: Integer; - NamedFiles: Integer; - Extensions: Integer; - DataAddr: Integer; - DataSize: Integer; - NamesAddr: Integer; - NamesSize: Integer; - Ident2: array[0..$F] of Byte; - end; - TFilesMap = array of packed record - Extension: array[0..$3] of Char; - DataAddr: Integer; - NameAddr: Integer; - FileSize: Integer; - FileType: LongWord; - end; - TNamedFilesMap = array of packed record - FileNumber: Integer; - blubb: Integer; - end; const header_ident1_pc: array[0..$13] of Byte = ($1F, $27, $DC, $33, $DF, $BC, $03, $00, $31, $33, $52, $56, $40, $00, @@ -183,6 +160,7 @@ begin Msg := SM_OK; FBackend := DB_ONI; + FConnectionID := ConnectionID; FChangeRights := [CR_EditDat, CR_EditRaw, CR_AppendRaw]; end; @@ -248,6 +226,12 @@ var name := fields.Strings[2]; extension := fields.Strings[0]; end; + if SortType in [ST_ExtNameAsc, ST_ExtNameDesc] then + begin + id := fields.Strings[2]; + name := fields.Strings[1]; + extension := fields.Strings[0]; + end; end; begin @@ -261,10 +245,7 @@ begin begin if (NoEmptyFiles = False) or ((Fdat_files[i].FileType and $02) = 0) then begin - if AppSettings.FilenumbersAsHex then - id := IntToHex(Fdat_files[i].ID, 4) - else - id := FormatNumber(Fdat_files[i].ID, 5, '0'); + id := FormatNumber(Fdat_files[i].ID, 5, '0'); name := Fdat_files[i].Name; extension := Fdat_files[i].Extension; @@ -272,6 +253,7 @@ begin ST_IDAsc, ST_IDDesc: list.Add(id + ';' + name + ';' + extension); ST_NameAsc, ST_NameDesc: list.Add(name + ';' + id + ';' + extension); ST_ExtAsc, ST_ExtDesc: list.Add(extension + ';' + id + ';' + name); + ST_ExtNameAsc, ST_ExtNameDesc: list.Add(name + ';' + extension + ';' + id); end; end; end; @@ -280,7 +262,7 @@ begin if list.Count > 0 then begin fields := TStringList.Create; - if SortType in [ST_IDAsc, ST_NameAsc, ST_ExtAsc] then + if SortType in [ST_IDAsc, ST_NameAsc, ST_ExtAsc, ST_ExtNameAsc] then for i := 0 to list.Count - 1 do begin getfields; @@ -615,7 +597,7 @@ begin end; end; -function TAccess_OniArchive.AppendRawFile(LocSep: Boolean; Size: Integer; Src: TStream): Integer; +function TAccess_OniArchive.AppendRawFile(LocSep: Boolean; Src: TStream): Integer; begin if not LocSep then begin @@ -624,7 +606,7 @@ begin fmOpenReadWrite); Result := Fraw_file.Size; Fraw_file.Seek(0, soFromEnd); - Fraw_file.CopyFrom(Src, Size); + Fraw_file.CopyFrom(Src, Src.Size); if UnloadWhenUnused then begin FRawOpened := False; @@ -640,7 +622,7 @@ begin fmOpenReadWrite); Result := Fsep_file.Size; Fsep_file.Seek(0, soFromEnd); - Fsep_file.CopyFrom(Src, Size); + Fsep_file.CopyFrom(Src, Src.Size); if UnloadWhenUnused then begin FSepOpened := False;