From f586979ac56a2538bc05ea7697c3cf7363d0d624 Mon Sep 17 00:00:00 2001 From: leo Date: Mon, 2 Sep 2024 07:54:46 +0800 Subject: [PATCH] fix: crash when scan repositories under default clone dir (#434) --- src/ViewModels/ScanRepositories.cs | 28 +++++++++++++++++++--------- 1 file changed, 19 insertions(+), 9 deletions(-) diff --git a/src/ViewModels/ScanRepositories.cs b/src/ViewModels/ScanRepositories.cs index a7a9ab7b..73bb6916 100644 --- a/src/ViewModels/ScanRepositories.cs +++ b/src/ViewModels/ScanRepositories.cs @@ -12,7 +12,7 @@ namespace SourceGit.ViewModels { get; private set; - } = string.Empty; + } public ScanRepositories(string rootDir) { @@ -28,7 +28,7 @@ namespace SourceGit.ViewModels return Task.Run(() => { - // If it is too fast, the panel will dispear very quickly, the we'll have a bad experience. + // If it is too fast, the panel will disappear very quickly, then we'll have a bad experience. Task.Delay(500).Wait(); var rootDir = new DirectoryInfo(RootDir); @@ -42,14 +42,24 @@ namespace SourceGit.ViewModels Dispatcher.UIThread.Invoke(() => { var normalizedRoot = rootDir.FullName.Replace("\\", "/"); - var prefixLen = normalizedRoot.EndsWith('/') ? normalizedRoot.Length : normalizedRoot.Length + 1; - + foreach (var f in founded) { - var fullpath = new DirectoryInfo(f); - var relative = fullpath.Parent!.FullName.Replace("\\", "/").Substring(prefixLen); - var group = FindOrCreateGroupRecursive(Preference.Instance.RepositoryNodes, relative); - Preference.Instance.FindOrAddNodeByRepositoryPath(f, group, false); + var parent = new DirectoryInfo(f).Parent!.FullName.Replace("\\", "/"); + if (parent.Equals(normalizedRoot, StringComparison.Ordinal)) + { + Preference.Instance.FindOrAddNodeByRepositoryPath(f, null, false); + } + else if (parent.StartsWith(normalizedRoot, StringComparison.Ordinal)) + { + var relative = parent.Substring(normalizedRoot.Length).TrimStart('/'); + var group = FindOrCreateGroupRecursive(Preference.Instance.RepositoryNodes, relative); + Preference.Instance.FindOrAddNodeByRepositoryPath(f, group, false); + } + else + { + // Should not happen. + } } Welcome.Instance.Refresh(); @@ -61,7 +71,7 @@ namespace SourceGit.ViewModels private void GetManagedRepositories(List group, HashSet repos) { - foreach (RepositoryNode node in group) + foreach (var node in group) { if (node.IsRepository) repos.Add(node.Id);