enhance: do not show Initialize Repository popup for bare repositories (#891)

This commit is contained in:
leo 2025-01-13 17:37:23 +08:00
parent 632222a776
commit 5f4c1bb984
No known key found for this signature in database
3 changed files with 34 additions and 60 deletions

View file

@ -1,5 +1,4 @@
using System;
using System.IO;
using Avalonia;
using Avalonia.Controls;
@ -197,7 +196,7 @@ namespace SourceGit.Views
{
foreach (var item in items)
{
OpenOrInitRepository(item.Path.LocalPath);
ViewModels.Welcome.Instance.OpenOrInitRepository(item.Path.LocalPath, null, true);
break;
}
}
@ -261,7 +260,7 @@ namespace SourceGit.Views
{
foreach (var item in items)
{
OpenOrInitRepository(item.Path.LocalPath, to);
ViewModels.Welcome.Instance.OpenOrInitRepository(item.Path.LocalPath, to, true);
break;
}
}
@ -290,37 +289,6 @@ namespace SourceGit.Views
}
}
private void OpenOrInitRepository(string path, ViewModels.RepositoryNode parent = null)
{
if (!Directory.Exists(path))
{
if (File.Exists(path))
path = Path.GetDirectoryName(path);
else
return;
}
var isBare = new Commands.IsBareRepository(path).Result();
if (isBare)
{
App.RaiseException(string.Empty, $"'{path}' is a bare repository, which is not supported by SourceGit!");
return;
}
var test = new Commands.QueryRepositoryRootPath(path).ReadToEnd();
if (!test.IsSuccess || string.IsNullOrEmpty(test.StdOut))
{
ViewModels.Welcome.Instance.InitRepository(path, parent, test.StdErr);
return;
}
var node = ViewModels.Preferences.Instance.FindOrAddNodeByRepositoryPath(test.StdOut.Trim(), parent, true);
ViewModels.Welcome.Instance.Refresh();
var launcher = this.FindAncestorOfType<Launcher>()?.DataContext as ViewModels.Launcher;
launcher?.OpenRepositoryInTab(node, launcher.ActivePage);
}
private bool _pressedTreeNode = false;
private Point _pressedTreeNodePosition = new Point();
private bool _startDragTreeNode = false;