.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 4ccfc39444 Fix #1491: Exception on empty resource 6 years ago
BuildTools Ignore indentation of file 'Resources.Designer.cs' 6 years ago
ICSharpCode.Decompiler Fix #1491: Exception on empty resource 6 years ago
ICSharpCode.Decompiler.Console Update samples & ilspycmd to 5.0.0.4688-preview1 6 years ago
ICSharpCode.Decompiler.PdbProvider.Cecil See #1416. Also upgraded Cecil to .3 (from .1) 6 years ago
ICSharpCode.Decompiler.PowerShell Update samples & ilspycmd to 5.0.0.4688-preview1 6 years ago
ICSharpCode.Decompiler.Tests Merge branch 'master' of https://github.com/icsharpcode/ILSpy into fixed-buffers 6 years ago
ILSpy Fix #1491: Exception on empty resource 6 years ago
ILSpy-tests@e83c25d910 Update ILSpy-tests submodule reference. 7 years ago
ILSpy.AddIn Merge branch 'master' of https://github.com/icsharpcode/ILSpy 6 years ago
ILSpy.BamlDecompiler Fix #1503: Implement StaticResourceStartHandler and StaticResourceIdHandler 6 years ago
ILSpy.BamlDecompiler.Tests Fix #1436: Do not crash on unknown assembly reference. 6 years ago
ILSpy.Tests Update to Roslyn 3.0.0-beta4 6 years ago
SharpTreeView See #1416. Also upgraded Cecil to .3 (from .1) 6 years ago
TestPlugin See #1416. Also upgraded Cecil to .3 (from .1) 6 years ago
doc Update copyright year 6 years ago
.editorconfig Convert most Rebracer rules to .editorconfig (natively supported by VS) 8 years ago
.gitattributes Add .gitattributes and normalize newlines 12 years ago
.gitignore Add disassembler test temp files to git ignore. 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 samples & ilspycmd to 5.0.0.4688-preview1 6 years ago
Frontends.sln Remove references to non-existent Rebracer.xml and apply .editorconfig formatting to projects in Frontends.sln. 7 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 Fix can't package satellite DLL 6 years ago
clean.bat Remove references to Mono.Cecil from bat files. 8 years ago
debugbuild.bat Remove references to Mono.Cecil from bat files. 8 years ago
global.json Switch to MSBuild.Sdk.Extras for WPF support 6 years ago
preparerelease.bat Add preparerelease.bat 8 years ago
releasebuild.bat Remove references to Mono.Cecil from bat files. 8 years ago

README.md

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

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

Download: latest release | latest CI build (master)

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 (minimum version: 2017.7) with the following components:
    • Workload ".NET Desktop Development"
    • .NET Framework 4.6.2 Targeting Pack (if the VS installer does not offer this option, install the .NET 4.6.2 developer pack separately)
    • Individual Component "VC++ 2017 version 15.9 v14.16 latest v141 tools" (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.
  • Install the .NET Core SDK 2.2
  • 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

Unix:

  • Make sure .NET Core 2.2 is installed (you can get it here: https://get.dot.net).
  • 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 (cli and powershell core).

(Visual Studio for Mac users only:)

  • Edit \ICSharpCode.Decompiler\ICSharpCode.Decompiler.csproj Add Sdk="Microsoft.NET.Sdk" to the Project element. This is required due to a tooling issue. Please do not commit this when contributing a pull request!
  • Use Frontends.sln to work.

How to contribute

Current and past contributors.