From dd1621a811459da26b8fc2d993ec50c2f2b50704 Mon Sep 17 00:00:00 2001 From: Siegfried Pammer Date: Mon, 23 Aug 2021 14:29:21 +0200 Subject: [PATCH] Fix #2481: Remove 4 characters length requirement in regex search. --- ILSpy/Search/AbstractSearchStrategy.cs | 36 +++++++++++++++++++------- 1 file changed, 26 insertions(+), 10 deletions(-) diff --git a/ILSpy/Search/AbstractSearchStrategy.cs b/ILSpy/Search/AbstractSearchStrategy.cs index 74e6cd2c3..dc1e23f5d 100644 --- a/ILSpy/Search/AbstractSearchStrategy.cs +++ b/ILSpy/Search/AbstractSearchStrategy.cs @@ -25,14 +25,10 @@ namespace ICSharpCode.ILSpy.Search if (terms.Length == 1 && terms[0].Length > 2) { string search = terms[0]; - if (search.StartsWith("/", StringComparison.Ordinal) && search.Length > 4) + if (TryParseRegex(search, out regex)) { - var regexString = search.Substring(1, search.Length - 1); fullNameSearch = search.Contains("\\."); omitGenerics = !search.Contains("<"); - if (regexString.EndsWith("/", StringComparison.Ordinal)) - regexString = regexString.Substring(0, regexString.Length - 1); - regex = SafeNewRegex(regexString); } else { @@ -129,15 +125,35 @@ namespace ICSharpCode.ILSpy.Search resultQueue.TryAdd(result); } - Regex SafeNewRegex(string unsafePattern) + bool TryParseRegex(string input, out Regex pattern) { - try + pattern = null; + if (!input.StartsWith("/", StringComparison.Ordinal)) { - return new Regex(unsafePattern, RegexOptions.Compiled); + return false; + } + input = input.Substring(1); + if (input.EndsWith("/", StringComparison.Ordinal)) + { + input = input.Remove(input.Length - 1); } - catch (ArgumentException) + if (string.IsNullOrWhiteSpace(input)) { - return null; + return false; + } + pattern = SafeNewRegex(input); + return pattern != null; + + static Regex SafeNewRegex(string unsafePattern) + { + try + { + return new Regex(unsafePattern, RegexOptions.Compiled); + } + catch (ArgumentException) + { + return null; + } } } }