X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Fgame%2Fg_res_downloader.pas;h=05dfc24941c070fa76adb7d9db2ee5b84a74932d;hb=ac201b02f10ef558087d50f6b03b4519ab567558;hp=9547335009a7296361e17b018196f7e6846c3278;hpb=dfd3e97bffa213f5b21206b8a292b80180bab948;p=d2df-sdl.git diff --git a/src/game/g_res_downloader.pas b/src/game/g_res_downloader.pas index 9547335..05dfc24 100644 --- a/src/game/g_res_downloader.pas +++ b/src/game/g_res_downloader.pas @@ -1,3 +1,4 @@ +{$MODE DELPHI} unit g_res_downloader; interface @@ -9,7 +10,7 @@ function g_Res_DownloadWAD(const FileName: string): string; implementation -uses g_language; +uses g_language, sfs, utils, wadreader; const DOWNLOAD_DIR = 'downloads'; @@ -23,15 +24,14 @@ begin repeat if (searchResult.Attr and faDirectory) = 0 then begin - if searchResult.Name = filename then + if StrEquCI1251(searchResult.Name, filename) then begin files.Add(dirName+'/'+filename); Exit; end; end else if (searchResult.Name <> '.') and (searchResult.Name <> '..') then - FindFiles(IncludeTrailingPathDelimiter(dirName)+searchResult.Name, - filename, files); + FindFiles(IncludeTrailingPathDelimiter(dirName)+searchResult.Name, filename, files); until FindNext(searchResult) <> 0; finally FindClose(searchResult); @@ -42,14 +42,21 @@ end; function CompareFileHash(const filename: string; const resMd5: TMD5Digest): Boolean; var gResHash: TMD5Digest; + fname: string; begin - gResHash := MD5File(filename); + fname := findDiskWad(filename); + if length(fname) = 0 then begin result := false; exit; end; + gResHash := MD5File(fname); Result := MD5Match(gResHash, resMd5); end; function CheckFileHash(const path, filename: string; const resMd5: TMD5Digest): Boolean; +var + fname: string; begin - Result := FileExists(path + filename) and CompareFileHash(path + filename, resMd5); + fname := findDiskWad(path+filename); + if length(fname) = 0 then begin result := false; exit; end; + Result := FileExists(fname) and CompareFileHash(fname, resMd5); end; function g_Res_SearchSameWAD(const path, filename: string; const resMd5: TMD5Digest): string; @@ -84,15 +91,14 @@ end; function SaveWAD(const path, filename: string; const data: array of Byte): string; var - resFile: TFileStream; + resFile: TStream; + dpt: string; begin try - Result := path + DOWNLOAD_DIR + '/' + filename; - if not DirectoryExists(path + DOWNLOAD_DIR) then - begin - CreateDir(path + DOWNLOAD_DIR); - end; - resFile := TFileStream.Create(Result, fmCreate); + result := path+DOWNLOAD_DIR+'/'+filename; + dpt := path+DOWNLOAD_DIR; + if not findFileCI(dpt, true) then CreateDir(dpt); + resFile := createDiskFile(result); resFile.WriteBuffer(data[0], Length(data)); resFile.Free except @@ -103,7 +109,7 @@ end; function g_Res_DownloadWAD(const FileName: string): string; var msgStream: TMemoryStream; - resStream: TFileStream; + resStream: TStream; mapData: TMapDataMsg; i: Integer; resData: TResDataMsg; @@ -135,9 +141,7 @@ begin msgStream := g_Net_Wait_Event(NET_MSG_RES_RESPONSE); resData := ResDataFromMsgStream(msgStream); - resStream := TFileStream.Create(GameDir+'/wads/'+ - mapData.ExternalResources[i].Name, - fmCreate); + resStream := createDiskFile(GameDir+'/wads/'+mapData.ExternalResources[i].Name); resStream.WriteBuffer(resData.FileData[0], resData.FileSize); resData.FileData := nil;