diff --git a/src/game/g_map.pas b/src/game/g_map.pas
index 08ebadeb2929d4b429c62c9a7794173bfb0995cc..60aefbda87e3e205fc952aa4b142fbb2cb763d02 100644 (file)
--- a/src/game/g_map.pas
+++ b/src/game/g_map.pas
gLiftMap: array of array of DWORD;
gWADHash: TMD5Digest;
BackID: DWORD = DWORD(-1);
gLiftMap: array of array of DWORD;
gWADHash: TMD5Digest;
BackID: DWORD = DWORD(-1);
- gExternalResources: TStringList;
+ gExternalResources: array of TDiskFileInfo = nil;
gMovingWallIds: array of Integer = nil;
gdbg_map_use_accel_render: Boolean = true;
gMovingWallIds: array of Integer = nil;
gdbg_map_use_accel_render: Boolean = true;
end
else
begin
end
else
begin
+ //e_LogWritefln('GetReplacementWad: 000: old=%s', [WadName]);
result := g_Res_FindReplacementWad(WadName);
result := g_Res_FindReplacementWad(WadName);
- if (result <> WadName) then
- begin
- //e_LogWritefln('GetReplacementWad: old=%s; new=%s', [WadName, result]);
- end
- else
+ //e_LogWritefln('GetReplacementWad: 001: old=%s; new=%s', [WadName, result]);
+ if (result = WadName) then
begin
result := GameDir+'/wads/'+result;
begin
result := GameDir+'/wads/'+result;
+ //e_LogWritefln('GetReplacementWad: 002: old=%s; new=%s', [WadName, result]);
end;
end;
end;
end;
end;
end;
+
function CreateTexture(RecName: AnsiString; Map: string; log: Boolean): Integer;
var
WAD: TWADFile;
function CreateTexture(RecName: AnsiString; Map: string; log: Boolean): Integer;
var
WAD: TWADFile;
Result := '';
end;
Result := '';
end;
-procedure addResToExternalResList(res: string);
+
+procedure addResToExternalResList (res: AnsiString);
+var
+ uname: AnsiString;
+ f: Integer;
+ fi: TDiskFileInfo;
begin
begin
- //e_LogWritefln('DBG: ***trying external resource %s', [res]);
- res := toLowerCase1251(extractWadName(res));
- // ignore "standart.wad"
- if (res <> '') {and (res <> 'standart.wad')} and (gExternalResources.IndexOf(res) = -1) then
+ if g_Game_IsClient or not g_Game_IsNet then exit;
+ if (length(res) = 0) then exit; // map wad
+ res := extractWadName(res);
+ if (length(res) = 0) then exit; // map wad
+ uname := toLowerCase1251(res);
+ // do not add duplicates
+ for f := 0 to High(gExternalResources) do
begin
begin
- //e_LogWritefln('DBG: added external resource %s', [res]);
- gExternalResources.Add(res);
+ if (gExternalResources[f].userName = uname) then exit;
end;
end;
-end;
-
-procedure generateExternalResourcesList({mapReader: TMapReader_1}map: TDynRecord);
-//var
- //textures: TTexturesRec1Array;
- //textures: TDynField;
- //trec: TDynRecord;
- //mapHeader: TMapHeaderRec_1;
- //i: integer;
- //resFile: String = '';
-begin
- if gExternalResources = nil then
- gExternalResources := TStringList.Create;
-
- gExternalResources.Clear;
-
- (*
- {
- textures := GetTextures(map);
- for i := 0 to High(textures) do
+ // add new resource
+ fi.userName := uname;
+ if (not GetDiskFileInfo(GameDir+'/wads/'+res, fi)) then
begin
begin
- addResToExternalResList(resFile);
+ fi.tag := -1;
+ end
+ else
+ begin
+ fi.tag := 0; // non-zero means "cannot caclucate hash"
+ try
+ fi.hash := MD5File(fi.diskName);
+ except
+ fi.tag := -1;
+ end;
end;
end;
- }
+ //e_LogWritefln('addext: res=[%s]; uname=[%s]; diskName=[%s]', [res, fi.userName, fi.diskName]);
+ SetLength(gExternalResources, length(gExternalResources)+1);
+ gExternalResources[High(gExternalResources)] := fi;
+end;
- textures := map['texture'];
- if (textures <> nil) then
+
+procedure compactExtResList ();
+var
+ src, dest: Integer;
+begin
+ src := 0;
+ dest := 0;
+ for src := 0 to High(gExternalResources) do
begin
begin
- for trec in textures do
+ if (gExternalResources[src].tag = 0) then
begin
begin
- addResToExternalResList(resFile);
+ // copy it
+ if (dest <> src) then gExternalResources[dest] := gExternalResources[src];
+ Inc(dest);
end;
end;
end;
end;
+ if (dest <> length(gExternalResources)) then SetLength(gExternalResources, dest);
+end;
- textures := nil;
- *)
-
- //mapHeader := GetMapHeader(map);
+procedure generateExternalResourcesList (map: TDynRecord);
+begin
+ SetLength(gExternalResources, 0);
addResToExternalResList(map.MusicName);
addResToExternalResList(map.SkyName);
end;
addResToExternalResList(map.MusicName);
addResToExternalResList(map.SkyName);
end;
if (gCurrentMap = nil) then
begin
FileName := g_ExtractWadName(Res);
if (gCurrentMap = nil) then
begin
FileName := g_ExtractWadName(Res);
- e_WriteLog('Loading map WAD: '+FileName, TMsgType.Notify);
+ e_LogWritefln('Loading map WAD [%s] (res=[%s])', [FileName, Res], TMsgType.Notify);
g_Game_SetLoadingText(_lc[I_LOAD_WAD_FILE], 0, False);
WAD := TWADFile.Create();
g_Game_SetLoadingText(_lc[I_LOAD_WAD_FILE], 0, False);
WAD := TWADFile.Create();
end;
end;
end;
end;
+ compactExtResList();
e_WriteLog('Done loading map.', TMsgType.Notify);
Result := True;
end;
e_WriteLog('Done loading map.', TMsgType.Notify);
Result := True;
end;