SYSLIB0036: Regex.CompileToAssembly は廃止されました

.NET 7 以降、Regex.CompileToAssembly メソッドは古い形式としてマークされています。 この API をコードで使用すると、コンパイル時に警告 SYSLIB0036 が生成されます。

.NET 5、.NET 6、および .NET Core のすべてのバージョンでは、Regex.CompileToAssemblyPlatformNotSupportedException がスローされます。 .NET Framework では、Regex.CompileToAssembly によって正規表現インスタンスをアセンブリにコンパイルできます。

回避策

正規表現ソース ジェネレーターを呼び出す GeneratedRegexAttribute 属性を使います。 コンパイル時に、ソース ジェネレーターで正規表現パターンとそのオプションに固有の API が生成されます。

// This attribute causes the regular expression pattern to be compiled into your assembly,
// which enables it to start up and run more quickly.
[GeneratedRegex("abc|def", RegexOptions.IgnoreCase)]
private static partial Regex MyRegex();

// ...

// Use the regular expression
if (MyRegex().IsMatch(text) { ... }

警告を抑制する

古い API を使う必要がある場合は、コードまたはプロジェクト ファイルで警告を抑制することができます。

単一の違反だけを抑制するには、ソース ファイルにプリプロセッサ ディレクティブを追加して警告を無効にしてから、再度有効にします。

// Disable the warning.
#pragma warning disable SYSLIB0036

// Code that uses obsolete API.
// ...

// Re-enable the warning.
#pragma warning restore SYSLIB0036

プロジェクトですべての SYSLIB0036 警告を抑制するには、プロジェクト ファイルに <NoWarn> プロパティを追加します。

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
   ...
   <NoWarn>$(NoWarn);SYSLIB0036</NoWarn>
  </PropertyGroup>
</Project>

詳細については、「警告を表示しない」を参照してください。