diff --git a/Source/Core/General/MapManager.cs b/Source/Core/General/MapManager.cs
index 5a4cc071..bc8792ca 100755
--- a/Source/Core/General/MapManager.cs
+++ b/Source/Core/General/MapManager.cs
@@ -948,16 +948,39 @@ namespace CodeImp.DoomBuilder
// Treat "save as" into the current archive as normal save.
bool isSaveAs = (purpose == SavePurpose.AsNewFile) && (newfilepathname != filepathname);
// On Save AS we have to copy the previous file to the new file
- if(isSaveAs)
+ if (isSaveAs)
{
// Copy if original file still exists
- if(File.Exists(filepathname)) File.Copy(filepathname, newfilepathname, true);
+ if (File.Exists(filepathname))
+ File.Copy(filepathname, newfilepathname, true);
}
- // If the target file exists, we need to rebuild it
- // [ZZ] The original code here would do some weird trickery with tempfiles.
- // I'm just finding the map lumps and deleting them on later stages.
- targetwad = new WAD(newfilepathname);
+ if (File.Exists(newfilepathname))
+ {
+ // If the target file exists, we need to rebuild it
+ // biwa. This somewhat restores the behavior that was change with commit b996d8a380056ed9cb3a3f90f3c534e29e77e53c
+ // Not rebuilding the WAD can cause issues with WADs that do not have their directory at the bottom.
+ // See https://github.com/jewalky/UltimateDoomBuilder/issues/531
+ origwadfile = newfilepathname + ".temp";
+ File.Move(newfilepathname, origwadfile);
+
+ // Open original file
+ WAD origwad = new WAD(origwadfile, true);
+
+ // Create new target file
+ targetwad = new WAD(newfilepathname) { IsIWAD = origwad.IsIWAD }; //mxd. Let's preserve wad type
+
+ CopyAllLumps(origwad, targetwad);
+
+ // Close original file and delete it
+ origwad.Dispose();
+ File.Delete(origwadfile);
+ }
+ else
+ {
+ // Create new target file
+ targetwad = new WAD(newfilepathname);
+ }
}
catch(Exception e)
{
@@ -1548,6 +1571,26 @@ namespace CodeImp.DoomBuilder
return tgtheaderindex;
}
+ ///
+ /// Copies all lumps from one WAD to another
+ ///
+ /// Source WAD
+ /// Target WAD
+ private static void CopyAllLumps(WAD source, WAD target)
+ {
+ // Go for all lumps
+ for (int i = 0; i < source.Lumps.Count; i++)
+ {
+ Lump srclump = source.Lumps[i];
+
+ // Copy lump over!
+ Lump tgtlump = target.Insert(srclump.Name, target.Lumps.Count, srclump.Length, false);
+ srclump.CopyTo(tgtlump);
+ }
+
+ target.WriteHeaders();
+ }
+
// This copies specific map lumps from one WAD to another
private void CopyLumpsByType(WAD source, string sourcemapname,
WAD target, string targetmapname,