ILRepack 2.0.37

dotnet add package ILRepack --version 2.0.37                
NuGet\Install-Package ILRepack -Version 2.0.37                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ILRepack" Version="2.0.37">
  <PrivateAssets>all</PrivateAssets>
  <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets>
</PackageReference>                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ILRepack --version 2.0.37                
#r "nuget: ILRepack, 2.0.37"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install ILRepack as a Cake Addin
#addin nuget:?package=ILRepack&version=2.0.37

// Install ILRepack as a Cake Tool
#tool nuget:?package=ILRepack&version=2.0.37                

Build status NuGet GitHub license
Gitter chat

Introduction

ILRepack is meant at replacing ILMerge / Mono.Merge.

The former being closed-source (now open-sourced), impossible to customize, slow, resource consuming and many more. The later being deprecated, unsupported, and based on an old version of Mono.Cecil.

Here we're using latest (slightly modified) Cecil sources (0.11.5), you can find the fork here.

Downloads

You can grab it using NuGet.

Or if you're old-school (and want to stay like that), this direct link will give you the latest nupkg file, which you can open as a zip file.

Dotnet Tool Installation

ILRepack can now be installed as a dotnet tool:

PS C:\> dotnet tool install -g dotnet-ilrepack

You can then run ILRepack using ilrepack.

[!Note] There's no need to use dotnet ilrepack, as the way the tool is installed into the dotnet tools path, all you need to do is issue the command ilrepack.

Syntax

A console application is available (can be used as DLL as well), using same syntax as ILMerge:

Syntax: ILRepack.exe [Options] /out:<path> <path_to_primary> [<other_assemblies> ...]

 - /help              displays this help
 - @<path>.rsp        response file containing additional arguments, one per line
 - /log:<logfile>     enable logging to a file (default is disabled)
 - /verbose           more detailed logging

 - /out:<path>        target assembly path, symbol/config/doc files will be written here as well
 - <path_to_primary>  primary assembly, gives the name, version to the merged one
 - <other_assemblies> other assemblies to merge with the primary one
 - /wildcards         allows (and resolves) file wildcards (e.g. *.dll) in input assemblies

 - /lib:<path>        path(s) to search directories to resolve referenced assemblies 
                      (can be specified multiple times).
                      If you get 'unable to resolve assembly' errors specify a path to a directory
                      where the assembly can be found.

 - /target:kind       target assembly kind [library|exe|winexe], default is same as primary assembly
 - /ver:M.X.Y.Z       target assembly version
 - /keyfile:<path>    keyfile to sign the output assembly
 - /keycontainer:<c>  key container
 - /delaysign         set the key, but don't sign the assembly

 - /internalize       make all types except in the first assembly 'internal'.
                      Types in the transitive closure of public API remain public.
 - /internalizeassembly:<path>
                      Internalize a specific assembly name (no extension).
                      May be specified more than once (one per assembly to internalize).
                      If specified, no need to also specify /internalize.
 - /internalize:<exclude_file>
                      Each line is either a regex/ full type name not to internalize
                      or an assembly name not to internalize (.dll extension optional)
 - /renameinternalized
                      rename each internalized type to a new unique name
 - /excludeinternalizeserializable
                      do not internalize types marked as Serializable

 - /allowdup:Type     keep duplicates of the specified type, may be specified more than once
 - /allowdup          if no other /allowdup arguments specified, allow all duplicate types
 - /union             merges types with identical names into one
 - /repackdrop:RepackDropAttribute 
                      allows dropping members denoted by this attribute name when merging
 - /allowduplicateresources 
                      allows to duplicate resources in output assembly (by default they're ignored)
 - /noRepackRes       do not add the resource '{ResourcesRepackStep.ILRepackListResourceName}' with all merged assembly names

 - /copyattrs         copy assembly attributes (by default only the primary assembly attributes are copied)
 - /attr:<path>       take assembly attributes from the given assembly file
 - /allowMultiple     when copyattrs is specified, allows multiple attributes (if type allows)
 - /targetplatform:P  specify target platform (v1, v1.1, v2, v4 supported)
 - /keepotherversionreferences
                      take reference assembly version into account when removing references

 - /preservetimestamp preserve original file PE timestamp
 - /skipconfig        skips merging config files
 - /illink            merge IL Linker files
 - /xmldocs           merges XML documentation as well
 - /ndebug            disables symbol file generation (omit this if you want symbols and debug information)
 - /zeropekind        allows assemblies with Zero PeKind (but obviously only IL will get merged)
 - /index             stores file:line debug information as type/method attributes (requires PDB)

 - /parallel          use as many CPUs as possible to merge the assemblies
 - /pause             pause execution once completed (good for debugging)

 - /usefullpublickeyforreferences - NOT IMPLEMENTED
 - /align             - NOT IMPLEMENTED
 - /closed            - NOT IMPLEMENTED

Note: for compatibility purposes, all Options are case insensitive, and can be specified using '/', '-' or '--' prefix.

How to build

Builds directly from within Visual Studio 2022, or using msbuild:

git clone --recursive https://github.com/gluck/il-repack.git
cd il-repack
msbuild

TODO

  • Crash-testing
  • Add remaining features from ILMerge (closed / align)
  • Un-fork Cecil
  • Merge import process & reference fixing

DONE

  • PDBs & MDBs should be merged (Thanks Simon)
  • Fixed internal method overriding public one which isn't allowed in the same assembly (Simon)
  • Attribute merge (/copyattrs)
  • XML documentation merge
  • Clean command line parameter parsing
  • Add usage / version
  • App.config merge
  • Internalizing types (Simon)
  • Delay signing (Simon)
  • Target platform selection (Simon)
  • Automatic internal type renaming

Sponsoring / Donations

If you like this tool and want to express your thanks, you can contribute either time to the project (issue triage or pull-requests) or donate money to the Free Software Foundation.

Donate

There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

NuGet packages (6)

Showing the top 5 NuGet packages that depend on ILRepack:

Package Downloads
ILRepack.FullAuto

Full automatic ILRepack executor on .NET, .NET Core and .NET Framework

Vostok.Sys.Metrics.ETW

Provides system metrics on Windows platform via ETW

PrzyjaznaFaktura

Biblioteka integracyjna z systemem PrzyjaznaFaktura

Publicise.MSBuild.Task

MSBuild task to make assemblies with all members public.

ClickLib

Package Description

GitHub repositories (22)

Showing the top 5 popular GitHub repositories that depend on ILRepack:

Repository Stars
HangfireIO/Hangfire
An easy way to perform background job processing in .NET and .NET Core applications. No Windows Service or separate process required
xunit/xunit
xUnit.net is a free, open source, community-focused unit testing tool for .NET.
JavScraper/Emby.Plugins.JavScraper
Emby/Jellyfin 的一个日本电影刮削器插件,可以从某些网站抓取影片信息。
obfuscar/obfuscar
Open source obfuscation tool for .NET assemblies
guryanovev/CrystalQuartz
pluggable UI for Quartz.NET
Version Downloads Last updated
2.0.37 0 2/5/2025
2.0.36 5,171 12/10/2024
2.0.35 13,839 10/2/2024
2.0.34 41,716 6/10/2024
2.0.33 11,962 5/10/2024
2.0.32 3,957 5/6/2024
2.0.31 8,130 4/21/2024
2.0.30 5,335 4/5/2024
2.0.28 4,090 3/19/2024
2.0.27 28,953 1/15/2024
2.0.26 1,465 1/10/2024
2.0.25 14,081 1/8/2024
2.0.24 952 1/7/2024
2.0.18 1,172,504 9/8/2019
2.0.17 166,871 5/21/2019
2.0.16 335,706 7/30/2018
2.0.15 175,514 12/7/2017
2.0.14 3,951 11/21/2017
2.0.13 157,016 4/6/2017
2.0.12 20,939 10/24/2016
2.0.11 8,825 8/22/2016
2.0.10 249,580 1/8/2016
2.0.9 4,637 12/16/2015
2.0.8 8,201 10/6/2015
2.0.5 8,582 8/19/2015
2.0.4 3,659 7/30/2015
2.0.3 3,113 7/22/2015
2.0.2 5,421 6/18/2015
2.0.1 7,046 6/14/2015
2.0.0 2,828 6/7/2015
1.26.0 38,904 5/2/2015
1.25.0 67,519 2/17/2014
1.24.0 3,338 1/20/2014
1.23.0 3,013 12/16/2013
1.22.2 5,207 3/3/2013
1.22.1 2,928 3/3/2013
1.22.0 3,053 3/3/2013
1.21.3 2,222 2/5/2013
1.21.2 2,101 1/23/2013
1.21.1 2,041 1/22/2013
1.20.0 3,362 12/1/2012
1.18.0 3,436 10/15/2012
1.17.0 4,043 10/3/2012