fix<Perference>: fix crashes on .NET 4.8

This commit is contained in:
李通洲 2021-09-08 10:35:59 +08:00
parent 50fe327a89
commit 9c2a55b75c
2 changed files with 5 additions and 3 deletions

3
.gitignore vendored
View file

@ -1,6 +1,7 @@
.idea .idea
.vs .vs
.vscode
bin bin
obj obj
publish publish
*.user *.user

View file

@ -17,12 +17,13 @@ namespace SourceGit.Views {
public string CRLF { get; set; } public string CRLF { get; set; }
public string Version { get; set; } public string Version { get; set; }
const int MAX_PATH = 260;
// https://docs.microsoft.com/en-us/windows/desktop/api/shlwapi/nf-shlwapi-pathfindonpathw // https://docs.microsoft.com/en-us/windows/desktop/api/shlwapi/nf-shlwapi-pathfindonpathw
// https://www.pinvoke.net/default.aspx/shlwapi.PathFindOnPath // https://www.pinvoke.net/default.aspx/shlwapi.PathFindOnPath
[DllImport("shlwapi.dll", CharSet = CharSet.Unicode, SetLastError = false)] [DllImport("shlwapi.dll", CharSet = CharSet.Unicode, SetLastError = false)]
private static extern bool PathFindOnPath([In, Out] StringBuilder pszFile, [In] string[] ppszOtherDirs); private static extern bool PathFindOnPath([In, Out] StringBuilder pszFile, [In] string[] ppszOtherDirs);
public bool EnableWindowsTerminal { get; set; } = PathFindOnPath(new StringBuilder("wt.exe"), null); public bool EnableWindowsTerminal { get; set; } = PathFindOnPath(new StringBuilder("wt.exe", MAX_PATH), null);
public Preference() { public Preference() {
UpdateGitInfo(false); UpdateGitInfo(false);
@ -64,7 +65,7 @@ namespace SourceGit.Views {
} }
private void SelectGitPath(object sender, RoutedEventArgs e) { private void SelectGitPath(object sender, RoutedEventArgs e) {
var sb = new StringBuilder("git.exe"); var sb = new StringBuilder("git.exe", MAX_PATH);
string dir = PathFindOnPath(sb, null) string dir = PathFindOnPath(sb, null)
? sb.ToString() ? sb.ToString()
: Environment.GetFolderPath(Environment.SpecialFolder.ProgramFiles); : Environment.GetFolderPath(Environment.SpecialFolder.ProgramFiles);