--- oup/current/DataAccess/Access_OUP_ADB.pas 2007/03/29 14:20:25 136 +++ oup/current/DataAccess/Access_OUP_ADB.pas 2007/06/20 10:57:51 229 @@ -46,7 +46,7 @@ type implementation uses - SysUtils, Data, Functions, ABSDecUtil, DB, DatLinks; + SysUtils, Data, Functions, ABSDecUtil, DB, DatLinks, StrUtils; (* @@ -90,7 +90,7 @@ begin end; if FQuery.FieldByName('name').AsString = 'lvl' then FLevelNumber := StrToInt(FQuery.FieldByName('value').AsString); - if FQuery.FieldByName('name').AsString = 'DataOS' then + if FQuery.FieldByName('name').AsString = 'os' then begin if FQuery.FieldByName('value').AsString = 'WIN' then FDataOS := DOS_WIN @@ -112,6 +112,8 @@ begin FChangeRights := [CR_EditDat, CR_EditRaw, CR_ResizeDat, CR_ResizeRaw]; UpdateListCache; + + inherited; end; @@ -213,6 +215,14 @@ end; + function CompareItems(List: TStringList; I1, I2: Integer): Integer; + var + s1, s2: String; + begin + s1 := MidStr(List[I1], 1, PosEx(';', List[I1], 6) - 1); + s2 := MidStr(List[I2], 1, PosEx(';', List[I2], 6) - 1); + Result := CompareStr(s1, s2); + end; function TAccess_OUP_ADB.GetFilesList(ext: String; pattern: String; NoEmptyFiles: Boolean; SortType: TSortType): TStrings; @@ -253,7 +263,10 @@ var begin list := TStringList.Create; - list.Sorted := True; + if SortType in [ST_ExtNameAsc, ST_ExtNameDesc] then + list.Sorted := False + else + list.Sorted := True; for i := 0 to GetFileCount - 1 do begin if ((Length(ext) = 0) or (Pos(Fdat_files[i].Extension, ext) > 0)) and @@ -275,6 +288,8 @@ begin end; end; end; + if SortType in [ST_ExtNameAsc, ST_ExtNameDesc] then + list.CustomSort(CompareItems); if not Assigned(Result) then Result := TStringList.Create; if list.Count > 0 then