Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,8 @@ DiffEngine manages launching and cleanup of diff tools. It is designed to be use
* **[Diffinity](/docs/diff-tool.md#diffinity)** Windows (Cost: Free with option to donate)
* **[ExamDiff](/docs/diff-tool.md#examdiff)** Windows (Cost: Paid)
* **[Guiffy](/docs/diff-tool.md#guiffy)** Windows/OSX (Cost: Paid)
* **[KDiff3](/docs/diff-tool.md#kdiff3)** Windows/OSX (Cost: Free)
* **[Kaleidoscope](/docs/diff-tool.md#kaleidoscope)** OSX (Cost: Paid)
* **[KDiff3](/docs/diff-tool.md#kdiff3)** Windows/OSX (Cost: Free)
* **[Meld](/docs/diff-tool.md#meld)** Windows/OSX/Linux (Cost: Free)
* **[MsExcelDiff](/docs/diff-tool.md#msexceldiff)** Windows (Cost: Free)
* **[MsWordDiff](/docs/diff-tool.md#msworddiff)** Windows (Cost: Free)
Expand Down
8 changes: 8 additions & 0 deletions src/DiffEngine.Tests/DefinitionsTest.cs
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,14 @@ static string GetOsSupport(OsSupport osSupport)
return builder.ToString();
}

[Test]
public async Task ToolOrderMatchesEnumOrder()
{
var definitionsOrder = Definitions.Tools.Select(_ => _.Tool).ToList();
var enumOrder = Enum.GetValues(typeof(DiffTool)).Cast<DiffTool>().ToList();
await Assert.That(definitionsOrder).IsEquivalentTo(enumOrder);
}

[Test]
public void WriteDefaultOrder()
{
Expand Down
1 change: 1 addition & 0 deletions src/DiffEngine/Definitions.cs
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ public static class Definitions
public static IReadOnlyCollection<Definition> Tools { get; }

static Definitions() =>
// Order determines default tool priority. Keep in sync with the DiffTool enum.
Tools =
[
Implementation.MsWordDiff(),
Expand Down
6 changes: 4 additions & 2 deletions src/DiffEngine/DiffTool.cs
Original file line number Diff line number Diff line change
@@ -1,7 +1,11 @@
namespace DiffEngine;

// The order of this enum determines the default tool priority in DiffTools.Resolved.
// Keep this order in sync with Definitions.Tools.
public enum DiffTool
{
MsWordDiff,
MsExcelDiff,
BeyondCompare,
P4Merge,
Kaleidoscope,
Expand All @@ -25,6 +29,4 @@ public enum DiffTool
VisualStudioCode,
VisualStudio,
Cursor,
MsWordDiff,
MsExcelDiff
}
2 changes: 1 addition & 1 deletion src/Directory.Build.props
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
<Project>
<PropertyGroup>
<NoWarn>CS1591;CS0649;NU1608;NU1109</NoWarn>
<Version>19.1.1</Version>
<Version>19.1.2</Version>
<AssemblyVersion>1.0.0</AssemblyVersion>
<PackageTags>Testing, Snapshot, Diff, Compare</PackageTags>
<Description>Launches diff tools based on file extensions. Designed to be consumed by snapshot testing libraries.</Description>
Expand Down
Loading