.NET Decompiler with support for PDB generation, ReadyToRun, Metadata (&more) - cross-platform!
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Siegfried Pammer 9b36f33f5c Fix CA1416: Properly specify SupportedOSPlatform in all platform-specific assemblies. 3 years ago
.github IntroduceQueryExpressions: Do not ignore attributes on lambdas 3 years ago
BuildTools Ditch nuspec.template 3 years ago
ICSharpCode.Decompiler Remove incomplete/wrong support for null-forgiving operator. 3 years ago
ICSharpCode.Decompiler.Console ilspycmd will only target net60 going forward (it might start depending on ILSpyX too) 3 years ago
ICSharpCode.Decompiler.PdbProvider.Cecil Fix "Select PDB" command when working with bundles. 5 years ago
ICSharpCode.Decompiler.PowerShell #2516: Add ILSpy.AddIn.slnf, ILSpy.Wpf.slnf and ILSpy.XPlat.slnf; replaces Frontends.sln 4 years ago
ICSharpCode.Decompiler.TestRunner Build self-contained test runners before running tests. 3 years ago
ICSharpCode.Decompiler.Tests Remove incomplete/wrong support for null-forgiving operator. 3 years ago
ILSpy Fix CA1416: Properly specify SupportedOSPlatform in all platform-specific assemblies. 3 years ago
ILSpy-tests@6f8860e420 Add test configuration for mcs 5.23.0 4 years ago
ILSpy.AddIn Fix ILSpyBuildPath and .exe.config -> .dll.config. Note: should use output from dotnet publish! 3 years ago
ILSpy.AddIn.Shared Rename ILSpy.AddIn.VS17 to ILSpy.AddIn.VS2022 4 years ago
ILSpy.AddIn.VS2022 Fix ILSpyBuildPath and .exe.config -> .dll.config. Note: should use output from dotnet publish! 3 years ago
ILSpy.BamlDecompiler Fix CA1416: Properly specify SupportedOSPlatform in all platform-specific assemblies. 3 years ago
ILSpy.BamlDecompiler.Tests Add additional tests for .NET 4.0 3 years ago
ILSpy.Installer Fix buildOutputDir. Note: should use output from dotnet publish! 3 years ago
ILSpy.ReadyToRun Fix CA1416: Properly specify SupportedOSPlatform in all platform-specific assemblies. 3 years ago
ILSpy.Tests Fix CA1416: Properly specify SupportedOSPlatform in all platform-specific assemblies. 3 years ago
SharpTreeView Fix up ILSpy.Tests + <Project> tag for all projects 3 years ago
TestPlugin Fix CA1416: Properly specify SupportedOSPlatform in all platform-specific assemblies. 3 years ago
doc Update (c) for 2022 3 years ago
.editorconfig #2128: change .editorconfig according to our new code style. 5 years ago
.git-blame-ignore-revs #2128: Add .git-blame-ignore-revs 5 years ago
.gitattributes Add .gitattributes and normalize newlines 12 years ago
.gitignore Ditch nuspec.template 3 years ago
.gitmodules Remove AD submodule. 6 years ago
.tgitconfig Add tgit.icon project config 11 years ago
.vsconfig Update build tools used by ILSpy to use .NET 5.0 instead of .NET Core 3.1 4 years ago
ILSpy.AddIn.slnf Update ILSpy.AddIn.slnf to include new ILSpy.AddIn projects. 4 years ago
ILSpy.Installer.slnf Fix and improve ILSpy.Installer project 4 years ago
ILSpy.Wpf.slnf #2516: Add ILSpy.AddIn.slnf, ILSpy.Wpf.slnf and ILSpy.XPlat.slnf; replaces Frontends.sln 4 years ago
ILSpy.XPlat.slnf #2516: Add ILSpy.AddIn.slnf, ILSpy.Wpf.slnf and ILSpy.XPlat.slnf; replaces Frontends.sln 4 years ago
ILSpy.sln Ditch nuspec.template 3 years ago
NuGet.config Switch to dotnet6-transport 4 years ago
README.md Update the tools that ILSpy is part of (or its decompilation engine) 4 years ago
clean.bat #1598: Fix .bat files to use VS2019. 6 years ago
debugbuild.bat Run nuget restore in the .bat files 6 years ago
decompiler-nuget-demos.ipynb Release of 7.2 P3 3 years ago
global.json Switch to using the .NET 6.0 SDK (LTS compared to 5.0). Removed unsupported TFM for ilspycmd, added net6.0. 4 years ago
packages.props Add additional tests for .NET 4.0 3 years ago
releasebuild.bat Run nuget restore in the .bat files 6 years ago

README.md

ILSpy NuGet Build ILSpy Twitter Follow ILSpy VS extension

ILSpy is the open-source .NET assembly browser and decompiler.

Download: latest release | latest CI build (master) | Microsoft Store (RC & RTM versions only)

Decompiler Frontends

Aside from the WPF UI ILSpy (downloadable via Releases, see also plugins), the following other frontends are available:

  • Visual Studio 2022 ships with decompilation support for F12 enabled by default (using our engine v6.1).
  • In Visual Studio 2019, you have to manually enable F12 support. Go to Tools / Options / Text Editor / C# / Advanced and check "Enable navigation to decompiled source"
  • C# for Visual Studio Code ships with decompilation support as well. To enable, activate the setting "Enable Decompilation Support".
  • Visual Studio 2022 extension marketplace
  • Visual Studio 2017/2019 extension marketplace
  • Visual Studio Code Extension repository | marketplace
  • Linux/Mac/Windows ILSpy UI based on Avalonia - check out https://github.com/icsharpcode/AvaloniaILSpy
  • ICSharpCode.Decompiler NuGet for your own projects
  • dotnet tool for Linux/Mac/Windows - check out ICSharpCode.Decompiler.Console in this repository
  • Linux/Mac/Windows PowerShell cmdlets in this repository

Features

  • Decompilation to C# (check out the language support status)
  • Whole-project decompilation (csproj, not sln!)
  • Search for types/methods/properties (learn about the options)
  • Hyperlink-based type/method/property navigation
  • Base/Derived types navigation, history
  • Assembly metadata explorer (feature walkthrough)
  • BAML to XAML decompiler
  • ReadyToRun binary support for .NET Core (see the tutorial)
  • Extensible via plugins
  • Additional features in DEBUG builds (for the devs)

License

ILSpy is distributed under the MIT License. Please see the About doc for details, as well as third party notices for included open-source libraries.

How to build

Windows:

  • Clone the ILSpy repository using git.
  • Execute git submodule update --init --recursive to download the ILSpy-Tests submodule (used by some test cases).
  • Install Visual Studio (documented version: 16.9). You can install the necessary components in one of 3 ways:
    • Follow Microsoft's instructions for importing a configuration, and import the .vsconfig file located at the root of the solution.
    • Alternatively, you can open the ILSpy solution (ILSpy.sln) and Visual Studio will prompt you to install the missing components.
    • Finally, you can manually install the necessary components via the Visual Studio Installer. The workloads/components are as follows:
      • Workload ".NET Desktop Development". This workload includes the .NET Framework 4.8 SDK and the .NET Framework 4.7.2 targeting pack, as well as the .NET 6.0 SDK (ILSpy.csproj targets .NET 4.7.2, and ILSpy.sln uses SDK-style projects). Note: The optional components of this workload are not required for ILSpy
      • Workload "Visual Studio extension development" (ILSpy.sln contains a VS extension project) Note: The optional components of this workload are not required for ILSpy
      • Individual Component "MSVC v142 - VS 2019 C++ x64/x86 build tools (v14.23)" (or similar)
        • The VC++ toolset is optional; if present it is used for editbin.exe to modify the stack size used by ILSpy.exe from 1MB to 16MB, because the decompiler makes heavy use of recursion, where small stack sizes lead to problems in very complex methods.
    • Open ILSpy.sln in Visual Studio.
      • NuGet package restore will automatically download further dependencies
      • Run project "ILSpy" for the ILSpy UI
      • Use the Visual Studio "Test Explorer" to see/run the tests
      • If you are only interested in a specific subset of ILSpy, you can also use
        • ILSpy.Wpf.slnf: for the ILSpy WPF frontend
        • ILSpy.XPlat.slnf: for the cross-platform CLI or PowerShell cmdlets
        • ILSpy.AddIn.slnf: for the Visual Studio plugin

Note: Visual Studio 16.3 and later include a version of the .NET (Core) SDK that is managed by the Visual Studio installer - once you update, it may get upgraded too. Please note that ILSpy is only compatible with the .NET 6.0 SDK and Visual Studio will refuse to load some projects in the solution (and unit tests will fail). If this problem occurs, please manually install the .NET 6.0 SDK from here.

Unix / Mac:

  • Make sure .NET 6.0 SDK is installed.
  • Make sure PowerShell is installed (formerly known as PowerShell Core)
  • Clone the repository using git.
  • Execute git submodule update --init --recursive to download the ILSpy-Tests submodule (used by some test cases).
  • Use dotnet build ILSpy.XPlat.slnf to build the non-Windows flavors of ILSpy (.NET Core Global Tool and PowerShell Core).

How to contribute

Current and past contributors.

Privacy Policy for ILSpy

ILSpy does not collect any personally identifiable information, nor does it send user files to 3rd party services. ILSpy does not use any APM (Application Performance Management) service to collect telemetry or metrics.