Skip to content

Commit

Permalink
Merge pull request #5665 from microsoft/chore/reduced-allocs-regex
Browse files Browse the repository at this point in the history
chore: reduces allocs for path parameters sanitation
  • Loading branch information
baywet authored Oct 24, 2024
2 parents 5da5649 + 8ecf006 commit 2d13e44
Showing 1 changed file with 8 additions and 5 deletions.
13 changes: 8 additions & 5 deletions src/Kiota.Builder/Extensions/OpenApiUrlTreeNodeExtensions.cs
Original file line number Diff line number Diff line change
@@ -261,15 +261,18 @@ private static IEnumerable<KeyValuePair<string, HashSet<string>>> GetRequestInfo
yield return new KeyValuePair<string, HashSet<string>>(currentNode.GetUrlTemplate(null, false, false).TrimStart('/'), operations.Select(static x => x.Key.ToString().ToUpperInvariant()).ToHashSet(StringComparer.OrdinalIgnoreCase));
}
}
[GeneratedRegex(@"{(?<paramname>[^}]+)}", RegexOptions.Singleline, 500)]
[GeneratedRegex(@"{[^}]+}", RegexOptions.Singleline, 500)]
private static partial Regex pathParamMatcher();
private static string SanitizePathParameterNamesForUrlTemplate(string original, HashSet<string> reservedParameterNames)
{
if (string.IsNullOrEmpty(original) || !original.Contains('{', StringComparison.OrdinalIgnoreCase)) return original;
var parameters = pathParamMatcher().Matches(original);
foreach (var value in parameters.Select(x => x.Groups["paramname"].Value))
original = original.Replace(value, (reservedParameterNames.Contains(value) ? "+" : string.Empty) + value.SanitizeParameterNameForUrlTemplate(), StringComparison.Ordinal);
return original;
var updated = original;
foreach (var match in pathParamMatcher().EnumerateMatches(original))
{
var value = original[(match.Index + 1)..(match.Index + match.Length - 1)];// ignore the { and }
updated = updated.Replace(value, (reservedParameterNames.Contains(value) ? "+" : string.Empty) + value.SanitizeParameterNameForUrlTemplate(), StringComparison.Ordinal);
}
return updated;
}
public static string SanitizeParameterNameForUrlTemplate(this string original)
{

0 comments on commit 2d13e44

Please sign in to comment.