Improve path/uri handling (#82)

* Improve file path special characters handling

* More specific tests

* Optimize EnhancedStackTrace.TryGetFullPath to prevent exceptions being thrown and the immediately re-caught
This commit is contained in:
Aristarkh Zagorodnikov 2019-02-10 23:49:22 +03:00 committed by Ben Adams
parent 9b85871130
commit 8604340a0e
2 changed files with 17 additions and 10 deletions

View File

@ -129,19 +129,11 @@ namespace System.Diagnostics
/// </summary>
public static string TryGetFullPath(string filePath)
{
try
if (Uri.TryCreate(filePath, UriKind.Absolute, out var uri) && uri.IsFile)
{
var uri = new Uri(filePath);
if (uri.IsFile)
{
return uri.AbsolutePath;
return Uri.UnescapeDataString(uri.AbsolutePath);
}
return uri.ToString();
}
catch (ArgumentException) { }
catch (UriFormatException) { }
return filePath;
}
}

View File

@ -21,6 +21,21 @@ namespace Ben.Demystifier.Test
Assert.Equal(expected, NormalizePath(converted));
}
[Theory]
[InlineData(@"file://Sources\My 100%.Done+Solution\Foo`1.cs", @"/My 100%.Done+Solution/Foo`1.cs", false)]
[InlineData(@"d:\Public Files+50%.Done\Src\Foo`1.cs", @"d:/Public Files+50%.Done/Src/Foo`1.cs", false)]
[InlineData(@"\.\Public Files+50%.Done\Src\Foo`1.cs", @"/./Public Files+50%.Done/Src/Foo`1.cs", true)]
public void SpecialPathCharactersAreHandledCorrectly(string original, string expected, bool normalize)
{
var converted = EnhancedStackTrace.TryGetFullPath(original);
if (normalize)
{
converted = NormalizePath(converted);
}
Assert.Equal(expected, converted);
}
// Used in tests to avoid platform-specific issues.
private static string NormalizePath(string path)
=> path.Replace("\\", "/");