dotnet-source-gen-regex
1
总安装量
1
周安装量
#52212
全站排名
安装命令
npx skills add https://github.com/im5tu/dotnet-skills --skill dotnet-source-gen-regex
Agent 安装分布
claude-code
1
Skill 文档
.NET Regex Source Generator
The regex source generator creates compile-time generated regex implementations that are:
- AOT-compatible: Works with Native AOT and trimming
- Debuggable: Step through the generated matching code
- Performant: No runtime compilation overhead
When to Use
This skill applies when the user:
- Wants to optimize regex performance
- Needs AOT-compatible regex patterns
- Asks about
[GeneratedRegex]attribute - Mentions converting
new Regex(...)to source-generated - Discusses regex compilation or startup performance
Workflow
-
Find regex usages in the codebase:
new Regex(...)constructor callsRegex.IsMatch(),Regex.Match(),Regex.Replace()static method calls- Other static
Regex.*methods with inline patterns
-
For each regex with a compile-time known pattern:
- Ensure the containing class is
partial - Create a partial method with
[GeneratedRegex]attribute:[GeneratedRegex("pattern", RegexOptions.IgnoreCase)] private static partial Regex MyRegex(); - Name the method descriptively based on what the pattern matches
- Ensure the containing class is
-
Replace usages to call the generated method:
// Before var regex = new Regex(@"\d+", RegexOptions.Compiled); if (regex.IsMatch(input)) { ... } // After if (MyNumberRegex().IsMatch(input)) { ... } [GeneratedRegex(@"\d+")] private static partial Regex MyNumberRegex(); -
Verify with
dotnet build -
If build fails, check:
- Class is marked
partial - Pattern is a compile-time constant
- .NET version is 7 or higher
- Class is marked
Key Notes
| Note | Detail |
|---|---|
RegexOptions.Compiled |
Ignored by source gen – remove it |
| .NET Version | Requires .NET 7+ |
| Caching | Generated method caches singleton internally |
| Timeout | Use [GeneratedRegex("pattern", RegexOptions.None, 1000)] for timeout (milliseconds) |
Pattern Conversion Examples
Instance with options:
// Before
private readonly Regex _emailRegex = new(@"^[\w-\.]+@[\w-]+\.\w+$", RegexOptions.Compiled | RegexOptions.IgnoreCase);
// After
[GeneratedRegex(@"^[\w-\.]+@[\w-]+\.\w+$", RegexOptions.IgnoreCase)]
private static partial Regex EmailRegex();
Static method call:
// Before
if (Regex.IsMatch(input, @"^\d{3}-\d{4}$"))
// After
if (PhoneNumberRegex().IsMatch(input))
[GeneratedRegex(@"^\d{3}-\d{4}$")]
private static partial Regex PhoneNumberRegex();
Error Handling
- If pattern is not constant: Cannot use source gen – leave as runtime regex
- If class is not partial: Add
partialmodifier to the class declaration - If build fails after conversion: Check error messages for unsupported pattern features