From 7aa94b1885a565a8fde21424f1c8b5805460e460 Mon Sep 17 00:00:00 2001 From: Rostislav Kirillov Date: Sat, 13 Jan 2024 22:08:32 +0400 Subject: [PATCH] feat: #21 --- src/SyncFaction.ModManager/XmlModels/ModInfo.cs | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/SyncFaction.ModManager/XmlModels/ModInfo.cs b/src/SyncFaction.ModManager/XmlModels/ModInfo.cs index a9e461f..86dc9a4 100644 --- a/src/SyncFaction.ModManager/XmlModels/ModInfo.cs +++ b/src/SyncFaction.ModManager/XmlModels/ModInfo.cs @@ -217,8 +217,13 @@ public ModInfoOperations BuildOperations() var fs = WorkDir.FileSystem; var relativeModFiles = WorkDir.EnumerateFiles("*", SearchOption.AllDirectories).ToImmutableDictionary(x => fs.Path.GetRelativePath(WorkDir.FullName, x.FullName.ToLowerInvariant())); + // ignore replaces where "default" was selected + var replacesWithoutNops = TypedChanges.OfType() + .Where(x => x.File != Extensions.NopName && x.NewFile != Extensions.NopName) + .ToList(); + // map replacements inside vpp to relative paths - var references = TypedChanges.OfType() + var references = replacesWithoutNops .Select(x => new { vppPath = GetPaths(fs, x.File), @@ -243,7 +248,7 @@ public ModInfoOperations BuildOperations() } var referencedFilesDict = referencedFiles.ToImmutableDictionary(static x => x.vppPath, static x => x.fileInfo!); - var replaceOperations = TypedChanges.OfType().Select((x, i) => ConvertToOperation(x, i, fs, referencedFilesDict)).ToList(); + var replaceOperations = replacesWithoutNops.Select((x, i) => ConvertToOperation(x, i, fs, referencedFilesDict)).ToList(); var editOperations = TypedChanges.OfType().Select((x, i) => ConvertToOperation(x, i, fs)).ToList(); return new ModInfoOperations(replaceOperations, editOperations); }