From de11a45d9ecd68a3957964fdddd3a146aef1af2e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jakub=20M=C3=AD=C5=A1ek?= Date: Fri, 14 Jun 2024 22:40:27 +0200 Subject: [PATCH] glob() avoids some allocs --- src/Peachpie.Library/FileSystem.Glob.cs | 26 ++++++++++++++++--------- 1 file changed, 17 insertions(+), 9 deletions(-) diff --git a/src/Peachpie.Library/FileSystem.Glob.cs b/src/Peachpie.Library/FileSystem.Glob.cs index 97e0216eaa..da34327102 100644 --- a/src/Peachpie.Library/FileSystem.Glob.cs +++ b/src/Peachpie.Library/FileSystem.Glob.cs @@ -292,7 +292,7 @@ private void DoGlob(string/*!*/ baseDirectory, int position) int patternEnd = FindNextSeparator(position, true, out var containsWildcard); bool isLastPathSegment = (patternEnd == _pattern.Length); - string dirSegment = _pattern.Substring(position, patternEnd - position); + var dirSegment = _pattern.AsSpan(position, patternEnd - position); if (!isLastPathSegment) { @@ -301,7 +301,7 @@ private void DoGlob(string/*!*/ baseDirectory, int position) if (!containsWildcard) { - var path = Path.Combine(baseDirectory, dirSegment); + var path = Path.Combine(baseDirectory, dirSegment.ToString()); TestPath(path, patternEnd, isLastPathSegment); return; } @@ -329,7 +329,7 @@ private void DoGlob(string/*!*/ baseDirectory, int position) { if (fnmatch(dirSegment, ".", _fnMatchFlags)) { - string directory = baseDirectory + CurrentPlatform.DirectorySeparatorString + "."; + var directory = baseDirectory + CurrentPlatform.DirectorySeparatorString + "."; if (_dirOnly) { directory += CurrentPlatform.DirectorySeparatorString; @@ -338,7 +338,7 @@ private void DoGlob(string/*!*/ baseDirectory, int position) } if (fnmatch(dirSegment, "..", _fnMatchFlags)) { - string directory = baseDirectory + CurrentPlatform.DirectorySeparatorString + ".."; + var directory = baseDirectory + CurrentPlatform.DirectorySeparatorString + ".."; if (_dirOnly) { directory += CurrentPlatform.DirectorySeparatorString; @@ -629,9 +629,9 @@ static void AppendExplicitRegexChar(StringBuilder/*!*/ builder, char c) builder.Append(']'); } - static string/*!*/ PatternToRegex(string/*!*/ pattern, bool pathName, bool noEscape) + static string/*!*/ PatternToRegex(ReadOnlySpan/*!*/pattern, bool pathName, bool noEscape) { - var result = new StringBuilder(pattern.Length); + var result = ObjectPools.GetStringBuilder(); result.Append("\\G"); bool inEscape = false; @@ -701,7 +701,15 @@ static void AppendExplicitRegexChar(StringBuilder/*!*/ builder, char c) } } - return (charClass == null) ? result.ToString() : string.Empty; + if (charClass == null) + { + return ObjectPools.GetStringAndReturn(result); + } + else + { + ObjectPools.Return(result); + return string.Empty; + } } static ValueList UngroupGlobs(string/*!*/ pattern, bool noEscape, bool brace) @@ -804,9 +812,9 @@ static ValueList UngroupGlobs(string/*!*/ pattern, bool noEscape, bool b /// Additional flags. /// true if the matches with the given /// wildcard . - public static bool fnmatch(string/*!*/ pattern, string/*!*/ path, FnMatchOptions flags = FnMatchOptions.None) + public static bool fnmatch(ReadOnlySpan/*!*/pattern, string/*!*/ path, FnMatchOptions flags = FnMatchOptions.None) { - if (string.IsNullOrEmpty(pattern)) + if (pattern.IsEmpty) { return string.IsNullOrEmpty(path); }