.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.
 
 
 
 
Daniel Grunwald 7326a69823 Fix #1795: `InvalidCastException: Cast from Boolean to Int64 not supported` when decompiling enum with bool constants 6 years ago
BuildTools Improve async/await decompilation when reference assemblies are missing 6 years ago
ICSharpCode.Decompiler Fix #1795: `InvalidCastException: Cast from Boolean to Int64 not supported` when decompiling enum with bool constants 6 years ago
ICSharpCode.Decompiler.Console Merge pull request #1740 from icsharpcode/issue1677 6 years ago
ICSharpCode.Decompiler.PdbProvider.Cecil See #1416. Also upgraded Cecil to .3 (from .1) 6 years ago
ICSharpCode.Decompiler.PowerShell Add LanguageVersion, RemoveDeadCode and RemoveDeadStores options to powershell cmdlet. 6 years ago
ICSharpCode.Decompiler.Tests Fix #1795: `InvalidCastException: Cast from Boolean to Int64 not supported` when decompiling enum with bool constants 6 years ago
ILSpy Merge pull request #1730 from icsharpcode/async-streams 6 years ago
ILSpy-tests@aa8f1197e6 Update ILSpy-tests 6 years ago
ILSpy.AddIn Ancsestor -> Ancestor 6 years ago
ILSpy.BamlDecompiler Update to latest MEF NuGet packages 6 years ago
ILSpy.BamlDecompiler.Tests Switch to net472, of note: 6 years ago
ILSpy.Package Back to neutral for package, Any CPU for build 6 years ago
ILSpy.Tests Upgrade Roslyn for tests to 3.3.1. 6 years ago
SharpTreeView commiting -> committing 6 years ago
TestPlugin Switch to net472, of note: 6 years ago
doc Update copyright year 6 years ago
.editorconfig Add YAML settings to editorconfig. Must use spaces 6 years ago
.gitattributes Add .gitattributes and normalize newlines 12 years ago
.gitignore Exclude wapproj generated directories 6 years ago
.gitmodules Upgrade to Cecil 0.10.0. 7 years ago
.tgitconfig Add tgit.icon project config 11 years ago
DecompilerNuGetDemos.workbook Update frontends for 5.0 RTM 6 years ago
Frontends.sln Try switching .Decompiler.Console on Release(NuGet)/Debug(ProjectRef). Tested on VS Mac 8.3 6 years ago
ILSpy.WithPackage.sln Bundle for x86 & x64 only, remove ARM targets 6 years ago
ILSpy.sln Translated the ICSharpCode.Decompiler‘s options and other 6 years ago
NuGet.config Add first attempt at PdbGenerationTestRunner. 6 years ago
README.md Update README.md 6 years ago
appveyor.yml Update to AvalonEdit 6.0 RTM 6 years ago
azure-pipelines.yml Use .NET Core 3.0 final SDK on Azure Pipelines 6 years ago
clean.bat #1598: Fix .bat files to use VS2019. 6 years ago
debugbuild.bat #1598: Fix .bat files to use VS2019. 6 years ago
global.json Remove old hacks for decompiler csproj 6 years ago
preparerelease.bat #1598: Fix .bat files to use VS2019. 6 years ago
releasebuild.bat #1598: Fix .bat files to use VS2019. 6 years ago

README.md

ILSpy Join the chat at https://gitter.im/icsharpcode/ILSpy NuGet Build status Twitter Follow ILSpy VS extension Build Status

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

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

CI Build Nuget Feed (master): https://ci.appveyor.com/nuget/ilspy-masterfeed

Decompiler Frontends

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

Features

  • Decompilation to C#
  • Whole-project decompilation (csproj, not sln!)
  • Search for types/methods/properties (substring)
  • Hyperlink-based type/method/property navigation
  • Base/Derived types navigation, history
  • BAML to XAML decompiler
  • Extensible via plugins (MEF)
  • Check out the language support status

License

ILSpy is distributed under the MIT License.

Included open-source libraries:

  • Mono.Cecil: MIT License (part of ILSpy)
  • LightJson: MIT License (part of ICSharpCode.Decompiler)
  • Humanizer: MIT License (part of ICSharpCode.Decompiler)
  • AvalonEdit: MIT License
  • SharpTreeView: LGPL
  • ILSpy.BamlDecompiler: MIT license
  • CommandLineUtils: Apache License 2.0 (part of ICSharpCode.Decompiler.Console)

How to build

Windows:

  • Install Visual Studio (documented version: 16.3) with the following components:
    • Workload ".NET Desktop Development". This includes by default .NET Framework 4.8 SDK and the .NET Framework 4.7.2 targeting pack, as well as the .NET Core 3.0 SDK (ILSpy.csproj targets .NET 4.7.2, and ILSpy.sln uses SDK-style projects).
    • Workload "Visual Studio extension development" (ILSpy.sln contains a VS extension project)
    • 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.
  • Check out the ILSpy repository using git.
  • Execute git submodule update --init --recursive to download the ILSpy-Tests submodule (used by some test cases).
  • 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

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 to 16.4 it may get upgraded to version 3.1. Please note that ILSpy is not compatible with the .NET Core 3.1 SDK and Visual Studio will refuse to load some projects in the solution. If this problem occurs, please manually install the .NET Core 3.0 SDK from here.

Unix / Mac:

  • Make sure .NET Core 2.1 LTS Runtime is installed (you can get it here: https://get.dot.net).
  • Make sure .NET Core 3.0 SDK is installed.
  • Check out the repository using git.
  • Execute git submodule update --init --recursive to download the ILSpy-Tests submodule (used by some test cases).
  • Use dotnet build Frontends.sln 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.