Browse Source

Merge pull request #54262 from raulsntos/csproj-globbing-3.x

Rémi Verschelde 4 years ago
parent
commit
23955fc282

+ 14 - 1
modules/mono/editor/GodotTools/GodotTools.ProjectEditor/ProjectUtils.cs

@@ -77,6 +77,19 @@ namespace GodotTools.ProjectEditor
             if (item == null)
             if (item == null)
                 return;
                 return;
 
 
+            // Check if the found item include already matches the new path
+            var glob = MSBuildGlob.Parse(item.Include);
+            if (glob.IsMatch(normalizedNewInclude))
+                return;
+
+            // Otherwise, if the item include uses globbing it's better to add a new item instead of modifying
+            if (!string.IsNullOrEmpty(glob.WildcardDirectoryPart) || glob.FilenamePart.Contains("*"))
+            {
+                root.AddItem(itemType, normalizedNewInclude.RelativeToPath(dir).Replace("/", "\\"));
+                root.Save();
+                return;
+            }
+
             item.Include = normalizedNewInclude.RelativeToPath(dir).Replace("/", "\\");
             item.Include = normalizedNewInclude.RelativeToPath(dir).Replace("/", "\\");
             root.Save();
             root.Save();
         }
         }
@@ -315,7 +328,7 @@ namespace GodotTools.ProjectEditor
 
 
             // Godot API References
             // Godot API References
 
 
-            var apiAssemblies = new[] {ApiAssemblyNames.Core, ApiAssemblyNames.Editor};
+            var apiAssemblies = new[] { ApiAssemblyNames.Core, ApiAssemblyNames.Editor };
 
 
             RemoveElements(root.ItemGroups.SelectMany(g => g.Items)
             RemoveElements(root.ItemGroups.SelectMany(g => g.Items)
                 .Where(i => i.ItemType == "Reference" && apiAssemblies.Contains(i.Include)));
                 .Where(i => i.ItemType == "Reference" && apiAssemblies.Contains(i.Include)));