ux: add icons for external merge tools
|
@ -2,16 +2,29 @@
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
|
||||||
|
using Avalonia.Media.Imaging;
|
||||||
|
using Avalonia.Platform;
|
||||||
|
|
||||||
namespace SourceGit.Models
|
namespace SourceGit.Models
|
||||||
{
|
{
|
||||||
public class ExternalMerger
|
public class ExternalMerger
|
||||||
{
|
{
|
||||||
public int Type { get; set; }
|
public int Type { get; set; }
|
||||||
|
public string Icon { get; set; }
|
||||||
public string Name { get; set; }
|
public string Name { get; set; }
|
||||||
public string Exec { get; set; }
|
public string Exec { get; set; }
|
||||||
public string Cmd { get; set; }
|
public string Cmd { get; set; }
|
||||||
public string DiffCmd { get; set; }
|
public string DiffCmd { get; set; }
|
||||||
|
|
||||||
|
public Bitmap IconImage
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
var icon = AssetLoader.Open(new Uri($"avares://SourceGit/Resources/ExternalToolIcons/{Icon}.png", UriKind.RelativeOrAbsolute));
|
||||||
|
return new Bitmap(icon);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static readonly List<ExternalMerger> Supported;
|
public static readonly List<ExternalMerger> Supported;
|
||||||
|
|
||||||
static ExternalMerger()
|
static ExternalMerger()
|
||||||
|
@ -19,48 +32,49 @@ namespace SourceGit.Models
|
||||||
if (OperatingSystem.IsWindows())
|
if (OperatingSystem.IsWindows())
|
||||||
{
|
{
|
||||||
Supported = new List<ExternalMerger>() {
|
Supported = new List<ExternalMerger>() {
|
||||||
new ExternalMerger(0, "Custom", "", "", ""),
|
new ExternalMerger(0, "custom_diff", "Custom", "", "", ""),
|
||||||
new ExternalMerger(1, "Visual Studio Code", "Code.exe", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(1, "vscode", "Visual Studio Code", "Code.exe", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(2, "Visual Studio Code - Insiders", "Code - Insiders.exe", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(2, "vscode_insiders", "Visual Studio Code - Insiders", "Code - Insiders.exe", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(3, "Visual Studio 2017/2019/2022", "vsDiffMerge.exe", "\"$REMOTE\" \"$LOCAL\" \"$BASE\" \"$MERGED\" /m", "\"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(3, "vs", "Visual Studio", "vsDiffMerge.exe", "\"$REMOTE\" \"$LOCAL\" \"$BASE\" \"$MERGED\" /m", "\"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(4, "Tortoise Merge", "TortoiseMerge.exe;TortoiseGitMerge.exe", "-base:\"$BASE\" -theirs:\"$REMOTE\" -mine:\"$LOCAL\" -merged:\"$MERGED\"", "-base:\"$LOCAL\" -theirs:\"$REMOTE\""),
|
new ExternalMerger(4, "tortoise_merge", "Tortoise Merge", "TortoiseMerge.exe;TortoiseGitMerge.exe", "-base:\"$BASE\" -theirs:\"$REMOTE\" -mine:\"$LOCAL\" -merged:\"$MERGED\"", "-base:\"$LOCAL\" -theirs:\"$REMOTE\""),
|
||||||
new ExternalMerger(5, "KDiff3", "kdiff3.exe", "\"$REMOTE\" -b \"$BASE\" \"$LOCAL\" -o \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(5, "kdiff3", "KDiff3", "kdiff3.exe", "\"$REMOTE\" -b \"$BASE\" \"$LOCAL\" -o \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(6, "Beyond Compare", "BComp.exe", "\"$REMOTE\" \"$LOCAL\" \"$BASE\" \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(6, "beyond_compare", "Beyond Compare", "BComp.exe", "\"$REMOTE\" \"$LOCAL\" \"$BASE\" \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(7, "WinMerge", "WinMergeU.exe", "-u -e \"$REMOTE\" \"$LOCAL\" \"$MERGED\"", "-u -e \"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(7, "win_merge", "WinMerge", "WinMergeU.exe", "-u -e \"$REMOTE\" \"$LOCAL\" \"$MERGED\"", "-u -e \"$LOCAL\" \"$REMOTE\""),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
else if (OperatingSystem.IsMacOS())
|
else if (OperatingSystem.IsMacOS())
|
||||||
{
|
{
|
||||||
Supported = new List<ExternalMerger>() {
|
Supported = new List<ExternalMerger>() {
|
||||||
new ExternalMerger(0, "Custom", "", "", ""),
|
new ExternalMerger(0, "custom_diff", "Custom", "", "", ""),
|
||||||
new ExternalMerger(1, "FileMerge", "/usr/bin/opendiff", "\"$BASE\" \"$LOCAL\" \"$REMOTE\" -ancestor \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(1, "xcode", "FileMerge", "/usr/bin/opendiff", "\"$BASE\" \"$LOCAL\" \"$REMOTE\" -ancestor \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(2, "Visual Studio Code", "/Applications/Visual Studio Code.app/Contents/Resources/app/bin/code", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(2, "vscode", "Visual Studio Code", "/Applications/Visual Studio Code.app/Contents/Resources/app/bin/code", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(3, "Visual Studio Code - Insiders", "/Applications/Visual Studio Code - Insiders.app/Contents/Resources/app/bin/code", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(3, "vscode_insiders", "Visual Studio Code - Insiders", "/Applications/Visual Studio Code - Insiders.app/Contents/Resources/app/bin/code", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(4, "KDiff3", "/Applications/kdiff3.app/Contents/MacOS/kdiff3", "\"$REMOTE\" -b \"$BASE\" \"$LOCAL\" -o \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(4, "kdiff3", "KDiff3", "/Applications/kdiff3.app/Contents/MacOS/kdiff3", "\"$REMOTE\" -b \"$BASE\" \"$LOCAL\" -o \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(5, "Beyond Compare", "/Applications/Beyond Compare.app/Contents/MacOS/bcomp", "\"$REMOTE\" \"$LOCAL\" \"$BASE\" \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(5, "beyond_compare", "Beyond Compare", "/Applications/Beyond Compare.app/Contents/MacOS/bcomp", "\"$REMOTE\" \"$LOCAL\" \"$BASE\" \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
else if (OperatingSystem.IsLinux())
|
else if (OperatingSystem.IsLinux())
|
||||||
{
|
{
|
||||||
Supported = new List<ExternalMerger>() {
|
Supported = new List<ExternalMerger>() {
|
||||||
new ExternalMerger(0, "Custom", "", "", ""),
|
new ExternalMerger(0, "custom_diff", "Custom", "", "", ""),
|
||||||
new ExternalMerger(1, "Visual Studio Code", "/usr/share/code/code", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(1, "vscode", "Visual Studio Code", "/usr/share/code/code", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(2, "Visual Studio Code - Insiders", "/usr/share/code-insiders/code-insiders", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(2, "vscode_insiders", "Visual Studio Code - Insiders", "/usr/share/code-insiders/code-insiders", "-n --wait \"$MERGED\"", "-n --wait --diff \"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(3, "KDiff3", "/usr/bin/kdiff3", "\"$REMOTE\" -b \"$BASE\" \"$LOCAL\" -o \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(3, "kdiff3", "KDiff3", "/usr/bin/kdiff3", "\"$REMOTE\" -b \"$BASE\" \"$LOCAL\" -o \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
||||||
new ExternalMerger(4, "Beyond Compare", "/usr/bin/bcomp", "\"$REMOTE\" \"$LOCAL\" \"$BASE\" \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
new ExternalMerger(4, "beyond_compare", "Beyond Compare", "/usr/bin/bcomp", "\"$REMOTE\" \"$LOCAL\" \"$BASE\" \"$MERGED\"", "\"$LOCAL\" \"$REMOTE\""),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Supported = new List<ExternalMerger>() {
|
Supported = new List<ExternalMerger>() {
|
||||||
new ExternalMerger(0, "Custom", "", "", ""),
|
new ExternalMerger(0, "custom_diff", "Custom", "", "", ""),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ExternalMerger(int type, string name, string exec, string cmd, string diffCmd)
|
public ExternalMerger(int type, string icon, string name, string exec, string cmd, string diffCmd)
|
||||||
{
|
{
|
||||||
Type = type;
|
Type = type;
|
||||||
|
Icon = icon;
|
||||||
Name = name;
|
Name = name;
|
||||||
Exec = exec;
|
Exec = exec;
|
||||||
Cmd = cmd;
|
Cmd = cmd;
|
||||||
|
|
|
@ -3,6 +3,9 @@ using System.Collections.Generic;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
|
||||||
|
using Avalonia.Media.Imaging;
|
||||||
|
using Avalonia.Platform;
|
||||||
|
|
||||||
namespace SourceGit.Models
|
namespace SourceGit.Models
|
||||||
{
|
{
|
||||||
public class ExternalTool
|
public class ExternalTool
|
||||||
|
@ -12,6 +15,15 @@ namespace SourceGit.Models
|
||||||
public string Executable { get; set; } = string.Empty;
|
public string Executable { get; set; } = string.Empty;
|
||||||
public string OpenCmdArgs { get; set; } = string.Empty;
|
public string OpenCmdArgs { get; set; } = string.Empty;
|
||||||
|
|
||||||
|
public Bitmap IconImage
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
var icon = AssetLoader.Open(new Uri($"avares://SourceGit/Resources/ExternalToolIcons/{Icon}.png", UriKind.RelativeOrAbsolute));
|
||||||
|
return new Bitmap(icon);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void Open(string repo)
|
public void Open(string repo)
|
||||||
{
|
{
|
||||||
Process.Start(new ProcessStartInfo()
|
Process.Start(new ProcessStartInfo()
|
||||||
|
@ -34,22 +46,22 @@ namespace SourceGit.Models
|
||||||
|
|
||||||
public void VSCode(Func<string> platform_finder)
|
public void VSCode(Func<string> platform_finder)
|
||||||
{
|
{
|
||||||
TryAdd("Visual Studio Code", "vscode.png", "\"{0}\"", "VSCODE_PATH", platform_finder);
|
TryAdd("Visual Studio Code", "vscode", "\"{0}\"", "VSCODE_PATH", platform_finder);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void VSCodeInsiders(Func<string> platform_finder)
|
public void VSCodeInsiders(Func<string> platform_finder)
|
||||||
{
|
{
|
||||||
TryAdd("Visual Studio Code - Insiders", "vscode_insiders.png", "\"{0}\"", "VSCODE_INSIDERS_PATH", platform_finder);
|
TryAdd("Visual Studio Code - Insiders", "vscode_insiders", "\"{0}\"", "VSCODE_INSIDERS_PATH", platform_finder);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Fleet(Func<string> platform_finder)
|
public void Fleet(Func<string> platform_finder)
|
||||||
{
|
{
|
||||||
TryAdd("JetBrains Fleet", "fleet.png", "\"{0}\"", "FLEET_PATH", platform_finder);
|
TryAdd("JetBrains Fleet", "fleet", "\"{0}\"", "FLEET_PATH", platform_finder);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void SublimeText(Func<string> platform_finder)
|
public void SublimeText(Func<string> platform_finder)
|
||||||
{
|
{
|
||||||
TryAdd("Sublime Text", "sublime_text.png", "\"{0}\"", "SUBLIME_TEXT_PATH", platform_finder);
|
TryAdd("Sublime Text", "sublime_text", "\"{0}\"", "SUBLIME_TEXT_PATH", platform_finder);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void TryAdd(string name, string icon, string args, string env, Func<string> finder)
|
public void TryAdd(string name, string icon, string args, string env, Func<string> finder)
|
||||||
|
|
|
@ -228,7 +228,7 @@ namespace SourceGit.Native
|
||||||
// There are two versions of PowerShell : pwsh.exe (preferred) and powershell.exe (system default)
|
// There are two versions of PowerShell : pwsh.exe (preferred) and powershell.exe (system default)
|
||||||
private string ChoosePowerShell()
|
private string ChoosePowerShell()
|
||||||
{
|
{
|
||||||
if (!string.IsNullOrEmpty(_powershellPath))
|
if (!string.IsNullOrEmpty(_powershellPath))
|
||||||
return _powershellPath;
|
return _powershellPath;
|
||||||
|
|
||||||
var localMachine = Microsoft.Win32.RegistryKey.OpenBaseKey(
|
var localMachine = Microsoft.Win32.RegistryKey.OpenBaseKey(
|
||||||
|
|
BIN
src/Resources/ExternalToolIcons/beyond_compare.png
Normal file
After Width: | Height: | Size: 8 KiB |
BIN
src/Resources/ExternalToolIcons/custom_diff.png
Normal file
After Width: | Height: | Size: 1.8 KiB |
BIN
src/Resources/ExternalToolIcons/kdiff3.png
Normal file
After Width: | Height: | Size: 2.9 KiB |
BIN
src/Resources/ExternalToolIcons/tortoise_merge.png
Normal file
After Width: | Height: | Size: 5.5 KiB |
BIN
src/Resources/ExternalToolIcons/vs.png
Normal file
After Width: | Height: | Size: 5 KiB |
BIN
src/Resources/ExternalToolIcons/win_merge.png
Normal file
After Width: | Height: | Size: 6.8 KiB |
BIN
src/Resources/ExternalToolIcons/xcode.png
Normal file
After Width: | Height: | Size: 7.5 KiB |
|
@ -276,7 +276,7 @@
|
||||||
<x:String x:Key="Text.Preference.GPG.Path.Placeholder" xml:space="preserve">Input path for installed gpg program</x:String>
|
<x:String x:Key="Text.Preference.GPG.Path.Placeholder" xml:space="preserve">Input path for installed gpg program</x:String>
|
||||||
<x:String x:Key="Text.Preference.GPG.UserKey" xml:space="preserve">User Signing Key</x:String>
|
<x:String x:Key="Text.Preference.GPG.UserKey" xml:space="preserve">User Signing Key</x:String>
|
||||||
<x:String x:Key="Text.Preference.GPG.UserKey.Placeholder" xml:space="preserve">User's gpg signing key</x:String>
|
<x:String x:Key="Text.Preference.GPG.UserKey.Placeholder" xml:space="preserve">User's gpg signing key</x:String>
|
||||||
<x:String x:Key="Text.Preference.Merger" xml:space="preserve">MERGE</x:String>
|
<x:String x:Key="Text.Preference.Merger" xml:space="preserve">EXTERNAL MERGE TOOL</x:String>
|
||||||
<x:String x:Key="Text.Preference.Merger.CustomDiffCmd" xml:space="preserve">Diff Command</x:String>
|
<x:String x:Key="Text.Preference.Merger.CustomDiffCmd" xml:space="preserve">Diff Command</x:String>
|
||||||
<x:String x:Key="Text.Preference.Merger.CustomMergeCmd" xml:space="preserve">Merge Command</x:String>
|
<x:String x:Key="Text.Preference.Merger.CustomMergeCmd" xml:space="preserve">Merge Command</x:String>
|
||||||
<x:String x:Key="Text.Preference.Merger.Path" xml:space="preserve">Install Path</x:String>
|
<x:String x:Key="Text.Preference.Merger.Path" xml:space="preserve">Install Path</x:String>
|
||||||
|
|
|
@ -303,10 +303,10 @@ namespace SourceGit.ViewModels
|
||||||
foreach (var tool in tools)
|
foreach (var tool in tools)
|
||||||
{
|
{
|
||||||
var dupTool = tool;
|
var dupTool = tool;
|
||||||
var icon = AssetLoader.Open(new Uri($"avares://SourceGit/Resources/ExternalToolIcons/{dupTool.Icon}", UriKind.RelativeOrAbsolute));
|
|
||||||
var item = new MenuItem();
|
var item = new MenuItem();
|
||||||
item.Header = App.Text("Repository.OpenIn", dupTool.Name);
|
item.Header = App.Text("Repository.OpenIn", dupTool.Name);
|
||||||
item.Icon = new Image { Width = 16, Height = 16, Source = new Bitmap(icon) };
|
item.Icon = new Image { Width = 16, Height = 16, Source = dupTool.IconImage };
|
||||||
item.Click += (o, e) =>
|
item.Click += (o, e) =>
|
||||||
{
|
{
|
||||||
dupTool.Open(_fullpath);
|
dupTool.Open(_fullpath);
|
||||||
|
|
|
@ -409,9 +409,20 @@
|
||||||
MinHeight="28"
|
MinHeight="28"
|
||||||
Padding="8,0"
|
Padding="8,0"
|
||||||
HorizontalAlignment="Stretch"
|
HorizontalAlignment="Stretch"
|
||||||
|
HorizontalContentAlignment="Left"
|
||||||
|
RenderOptions.BitmapInterpolationMode="HighQuality"
|
||||||
|
FontSize="{Binding DefaultFontSize}"
|
||||||
ItemsSource="{Binding Source={x:Static m:ExternalMerger.Supported}}"
|
ItemsSource="{Binding Source={x:Static m:ExternalMerger.Supported}}"
|
||||||
DisplayMemberBinding="{Binding Name, x:DataType=m:ExternalMerger}"
|
SelectedIndex="{Binding ExternalMergeToolType, Mode=TwoWay}">
|
||||||
SelectedIndex="{Binding ExternalMergeToolType, Mode=TwoWay}"/>
|
<ComboBox.ItemTemplate>
|
||||||
|
<DataTemplate x:DataType="{x:Type m:ExternalMerger}">
|
||||||
|
<Grid ColumnDefinitions="Auto,*">
|
||||||
|
<Image Grid.Column="0" Width="16" Height="16" Source="{Binding IconImage}" RenderOptions.BitmapInterpolationMode="HighQuality"/>
|
||||||
|
<TextBlock Grid.Column="1" Text="{Binding Name}" Margin="6,0,0,0"/>
|
||||||
|
</Grid>
|
||||||
|
</DataTemplate>
|
||||||
|
</ComboBox.ItemTemplate>
|
||||||
|
</ComboBox>
|
||||||
|
|
||||||
<TextBlock Grid.Row="1" Grid.Column="0"
|
<TextBlock Grid.Row="1" Grid.Column="0"
|
||||||
Text="{DynamicResource Text.Preference.Merger.Path}"
|
Text="{DynamicResource Text.Preference.Merger.Path}"
|
||||||
|
|