System.CodeDom
                             
                            
                                9.0.10
                            
                        
                    See the version list below for details.
dotnet add package System.CodeDom --version 9.0.10
NuGet\Install-Package System.CodeDom -Version 9.0.10
<PackageReference Include="System.CodeDom" Version="9.0.10" />
<PackageVersion Include="System.CodeDom" Version="9.0.10" />
<PackageReference Include="System.CodeDom" />
paket add System.CodeDom --version 9.0.10
#r "nuget: System.CodeDom, 9.0.10"
#:package System.CodeDom@9.0.10
#addin nuget:?package=System.CodeDom&version=9.0.10
#tool nuget:?package=System.CodeDom&version=9.0.10
About
Provides functionality for dynamically generating and compiling source code using the Code Document Object Model (CodeDOM).
It allows developers to represent code in a language-agnostic format and then generate code in multiple languages, such as C# and VB.NET. The primary use cases include creating dynamic code generation tools, runtime code generation, and facilitating code analysis or transformation.
For a new modern development consider using the .NET Compiler Platform SDK, in particular Roslyn source generators.
Key Features
- Write code using a common object model that can be translated into multiple programming languages.
- Generate and compile code at runtime based on the CodeDOM.
How to Use
Generating and compiling C# code:
using System.CodeDom;
using System.CodeDom.Compiler;
using Microsoft.CSharp;
// Create a new CodeCompileUnit to hold the code
var compileUnit = new CodeCompileUnit();
// Create a namespace
var codeNamespace = new CodeNamespace("MyNamespace");
compileUnit.Namespaces.Add(codeNamespace);
// Create a class
var classDeclaration = new CodeTypeDeclaration("MyClass")
{
    IsClass = true
};
codeNamespace.Types.Add(classDeclaration);
// Add a simple method to the class
var method = new CodeMemberMethod
{
    Name = "HelloWorld",
    ReturnType = new CodeTypeReference(typeof(void)),
};
classDeclaration.Members.Add(method);
var methodInvocation = new CodeMethodInvokeExpression(new CodeTypeReferenceExpression("Console"),
                                                      "WriteLine",
                                                      new CodePrimitiveExpression("Hello, World!"));
method.Statements.Add(methodInvocation);
// Generate C# code from the CodeDOM structure
CodeDomProvider provider = new CSharpCodeProvider();
using (var writer = new StringWriter())
{
    var codeGenereationOptions = new CodeGeneratorOptions()
    {
        BlankLinesBetweenMembers = false,
        IndentString = "  ",
    };
    provider.GenerateCodeFromCompileUnit(compileUnit, writer, codeGenereationOptions);
    Console.WriteLine(writer.GetStringBuilder().ToString());
}
This example generates:
//------------------------------------------------------------------------------
// <auto-generated>
//     This code was generated by a tool.
//
//     Changes to this file may cause incorrect behavior and will be lost if
//     the code is regenerated.
// </auto-generated>
//------------------------------------------------------------------------------
namespace MyNamespace {
  public class MyClass {
    private void HelloWorld() {
      Console.WriteLine("Hello, World!");
    }
  }
}
Main Types
The main types provided by this library are:
- System.CodeDom.CodeObject
- System.CodeDom.CodeCompileUnit
- System.CodeDom.CodeNamespace
- System.CodeDom.CodeTypeDeclaration
- System.CodeDom.CodeMemberMethod
- System.CodeDom.CodeTypeReference
- System.CodeDom.CodeMethodInvokeExpression
- System.CodeDom.CodeTypeReferenceExpression
- System.CodeDom.CodePrimitiveExpression
- System.CodeDom.Compiler.CodeDomProvider
- System.CodeDom.Compiler.CodeGeneratorOptions
- Microsoft.CSharp.CSharpCodeProvider
- Microsoft.VisualBasic.VBCodeProvider
Additional Documentation
Feedback & Contributing
System.CodeDom is released as open source under the MIT license. Bug reports and contributions are welcome at the GitHub repository.
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. | 
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. | 
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. | 
| .NET Framework | net461 was computed. net462 is compatible. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. | 
| MonoAndroid | monoandroid was computed. | 
| MonoMac | monomac was computed. | 
| MonoTouch | monotouch was computed. | 
| Tizen | tizen40 was computed. tizen60 was computed. | 
| Xamarin.iOS | xamarinios was computed. | 
| Xamarin.Mac | xamarinmac was computed. | 
| Xamarin.TVOS | xamarintvos was computed. | 
| Xamarin.WatchOS | xamarinwatchos was computed. | 
- 
                                                    .NETFramework 4.6.2- No dependencies.
 
- 
                                                    .NETStandard 2.0- No dependencies.
 
- 
                                                    net8.0- No dependencies.
 
- 
                                                    net9.0- No dependencies.
 
GitHub repositories (129)
Showing the top 20 popular GitHub repositories that depend on System.CodeDom:
| Repository | Stars | 
|---|---|
| microsoft/PowerToys 
                                                            Microsoft PowerToys is a collection of utilities that help you customize Windows and streamline everyday tasks
                                                         | |
| dotnet/maui 
                                                            .NET MAUI is the .NET Multi-platform App UI, a framework for building native device applications spanning mobile, tablet, and desktop.
                                                         | |
| dotnet/roslyn 
                                                            The Roslyn .NET compiler provides C# and Visual Basic languages with rich code analysis APIs.
                                                         | |
| chocolatey/choco 
                                                            Chocolatey - the package manager for Windows
                                                         | |
| dotnet/orleans 
                                                            Cloud Native application framework for .NET
                                                         | |
| dotnet/machinelearning 
                                                            ML.NET is an open source and cross-platform machine learning framework for .NET.
                                                         | |
| dotnet/wpf 
                                                            WPF is a .NET Core UI framework for building Windows desktop applications.
                                                         | |
| PrismLibrary/Prism 
                                                            Prism is a framework for building loosely coupled, maintainable, and testable XAML applications in WPF, Xamarin Forms, and Uno / Win UI Applications..
                                                         | |
| xamarin/Xamarin.Forms 
                                                            Xamarin.Forms is no longer supported. Migrate your apps to .NET MAUI.
                                                         | |
| dotnet/msbuild 
                                                            The Microsoft Build Engine (MSBuild) is the build platform for .NET and Visual Studio.
                                                         | |
| protobuf-net/protobuf-net 
                                                            Protocol Buffers library for idiomatic .NET 
                                                         | |
| dotnet/winforms 
                                                            Windows Forms is a .NET UI framework for building Windows desktop applications.
                                                         | |
| Azure/azure-powershell 
                                                            Microsoft Azure PowerShell
                                                         | |
| dotnetcore/FreeSql 
                                                            .NET aot orm, VB.NET/C# orm, Mysql/PostgreSQL/SqlServer/Oracle orm, Sqlite/Firebird/Clickhouse/DuckDB orm, 达梦/金仓/虚谷/翰高/高斯 orm, 神通 orm, 南大通用 orm, 国产 orm, TDengine orm, QuestDB orm, MsAccess orm.
                                                         | |
| tixl3d/tixl 
                                                            Tooll 3 is an open source software to create realtime motion graphics.
                                                         | |
| hardkoded/puppeteer-sharp 
                                                            Headless Chrome .NET API
                                                         | |
| dotnet/sdk 
                                                            Core functionality needed to create .NET Core projects, that is shared between Visual Studio and CLI
                                                         | |
| dotnet/macios 
                                                            .NET for iOS, Mac Catalyst, macOS, and tvOS provide open-source bindings of the Apple SDKs for use with .NET managed languages such as C#
                                                         | |
| IronLanguages/ironpython3 
                                                            Implementation of Python 3.x for .NET Framework that is built on top of the Dynamic Language Runtime.
                                                         | |
| ErikEJ/EFCorePowerTools 
                                                            Entity Framework Core Power Tools - reverse engineering, migrations and model visualization in Visual Studio & CLI
                                                         | 
| Version | Downloads | Last Updated | 
|---|---|---|
| 10.0.0-rc.2.25466.103 | 0 | 9/22/2025 | 
| 10.0.0-rc.1.25451.107 | 1 | 9/22/2025 | 
| 10.0.0-rc.1.25421.113 | 0 | 8/28/2025 | 
| 10.0.0-preview.7.25380.108 | 0 | 8/11/2025 | 
| 10.0.0-preview.7.25380.105 | 0 | 8/6/2025 | 
| 10.0.0-preview.6.25358.103 | 0 | 7/17/2025 | 
| 10.0.0-preview.6.25321.102 | 0 | 6/25/2025 | 
| 10.0.0-preview.5.25280.105 | 0 | 6/2/2025 | 
| 10.0.0-preview.5.25277.114 | 0 | 6/3/2025 | 
| 10.0.0-preview.5.25277.101 | 0 | 5/29/2025 | 
| 10.0.0-preview.5.25266.103 | 0 | 5/20/2025 | 
| 10.0.0-preview.4.25255.103 | 0 | 5/12/2025 | 
| 9.0.10 | 0 | 9/23/2025 | 
| 9.0.7 | 0 | 7/11/2025 | 
| 4.6.0-preview.19073.11 | 2 | 1/28/2019 | 
| 4.6.0-preview.18571.3 | 2 | 11/30/2018 |