Browse Source

Merge pull request #2016 from icsharpcode/fix-2013

Fix #2013: Add option to extract self-contained executables (PublishSingleFile).
pull/2030/head
Siegfried Pammer 5 years ago committed by GitHub
parent
commit
c96e10a8ef
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 4
      ILSpy.AddIn/ILSpy.AddIn.csproj
  2. 2
      ILSpy/ILSpy.csproj
  3. 75
      ILSpy/MainWindow.xaml.cs
  4. 15
      ILSpy/Properties/Resources.Designer.cs
  5. 9
      ILSpy/Properties/Resources.resx

4
ILSpy.AddIn/ILSpy.AddIn.csproj

@ -117,12 +117,14 @@ @@ -117,12 +117,14 @@
<AdditionalDependencies Include="$(ILSpyBuildPath)Mono.Cecil.Pdb.dll" />
<AdditionalDependencies Include="$(ILSpyBuildPath)ILSpy.BamlDecompiler.Plugin.dll" />
<AdditionalDependencies Include="$(ILSpyBuildPath)Microsoft.DiaSymReader*.dll" />
<AdditionalDependencies Include="$(ILSpyBuildPath)OSVersionHelper.dll" />
<AdditionalDependencies Include="$(ILSpyBuildPath)OSVersionHelper.dll" />
<AdditionalDependencies Include="$(ILSpyBuildPath)Xceed.Wpf.AvalonDock.dll" />
<AdditionalDependencies Include="$(ILSpyBuildPath)DataGridExtensions.dll" />
<AdditionalDependencies Include="$(ILSpyBuildPath)Iced.dll" />
<AdditionalDependencies Include="$(ILSpyBuildPath)ILCompiler.Reflection.ReadyToRun.dll" />
<AdditionalDependencies Include="$(ILSpyBuildPath)ILSpy.ReadyToRun.Plugin.dll" />
<AdditionalDependencies Include="$(ILSpyBuildPath)Microsoft.NET.HostModel.dll" />
<AdditionalDependencies Include="$(ILSpyBuildPath)Ookii.Dialogs.Wpf.dll" />
</ItemGroup>
<ItemGroup>

2
ILSpy/ILSpy.csproj

@ -56,6 +56,8 @@ @@ -56,6 +56,8 @@
<PackageReference Include="Mono.Cecil" Version="0.10.3" />
<PackageReference Include="OSVersionHelper" Version="1.0.11" />
<PackageReference Include="DataGridExtensions" Version="2.1.1" />
<PackageReference Include="Microsoft.NET.HostModel" Version="3.1.4" />
<PackageReference Include="Ookii.Dialogs.Wpf" Version="1.1.0" />
</ItemGroup>
<ItemGroup>

75
ILSpy/MainWindow.xaml.cs

@ -35,6 +35,7 @@ using System.Windows.Media; @@ -35,6 +35,7 @@ using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Threading;
using ICSharpCode.Decompiler;
using ICSharpCode.Decompiler.Documentation;
using ICSharpCode.Decompiler.Metadata;
@ -46,7 +47,13 @@ using ICSharpCode.ILSpy.TextView; @@ -46,7 +47,13 @@ using ICSharpCode.ILSpy.TextView;
using ICSharpCode.ILSpy.TreeNodes;
using ICSharpCode.ILSpy.ViewModels;
using ICSharpCode.TreeView;
using Microsoft.NET.HostModel.AppHost;
using Microsoft.NET.HostModel.Bundle;
using Microsoft.Win32;
using Ookii.Dialogs.Wpf;
using OSVersionHelper;
using Xceed.Wpf.AvalonDock.Layout.Serialization;
@ -994,15 +1001,55 @@ namespace ICSharpCode.ILSpy @@ -994,15 +1001,55 @@ namespace ICSharpCode.ILSpy
}
break;
default:
var asm = assemblyList.OpenAssembly(file);
if (asm != null) {
if (loadedAssemblies != null)
loadedAssemblies.Add(asm);
else {
var node = assemblyListTreeNode.FindAssemblyNode(asm);
if (node != null && focusNode) {
AssemblyTreeView.SelectedItems.Add(node);
lastNode = node;
if (IsAppBundle(file, out var headerOffset)) {
if (MessageBox.Show(this, Properties.Resources.OpenSelfContainedExecutableMessage, "ILSpy", MessageBoxButton.YesNo) == MessageBoxResult.No)
break;
var dialog = new VistaFolderBrowserDialog();
if (dialog.ShowDialog() != true)
break;
DockWorkspace.Instance.RunWithCancellation(ct => Task<AvalonEditTextOutput>.Factory.StartNew(() => {
var output = new AvalonEditTextOutput { Title = "Extracting " + file };
Stopwatch w = Stopwatch.StartNew();
output.WriteLine($"Extracting {file} to {dialog.SelectedPath}...");
var extractor = new Extractor(file, dialog.SelectedPath);
extractor.ExtractFiles();
output.WriteLine($"Done in {w.Elapsed}.");
return output;
}, ct)).Then(output => {
DockWorkspace.Instance.ShowText(output);
OpenFileDialog dlg = new OpenFileDialog();
dlg.Filter = ".NET assemblies|*.dll;*.exe;*.winmd";
dlg.Multiselect = true;
dlg.InitialDirectory = dialog.SelectedPath;
if (dlg.ShowDialog() == true) {
foreach (var item in dlg.FileNames) {
var asm = assemblyList.OpenAssembly(item);
if (asm != null) {
if (loadedAssemblies != null)
loadedAssemblies.Add(asm);
else {
var node = assemblyListTreeNode.FindAssemblyNode(asm);
if (node != null && focusNode) {
AssemblyTreeView.SelectedItems.Add(node);
lastNode = node;
}
}
}
}
}
}).HandleExceptions();
} else {
var asm = assemblyList.OpenAssembly(file);
if (asm != null) {
if (loadedAssemblies != null)
loadedAssemblies.Add(asm);
else {
var node = assemblyListTreeNode.FindAssemblyNode(asm);
if (node != null && focusNode) {
AssemblyTreeView.SelectedItems.Add(node);
lastNode = node;
}
}
}
}
@ -1012,6 +1059,16 @@ namespace ICSharpCode.ILSpy @@ -1012,6 +1059,16 @@ namespace ICSharpCode.ILSpy
if (lastNode != null && focusNode)
AssemblyTreeView.FocusNode(lastNode);
}
bool IsAppBundle(string filename, out long bundleHeaderOffset)
{
try {
return HostWriter.IsBundle(filename, out bundleHeaderOffset);
} catch (Exception) {
bundleHeaderOffset = -1;
return false;
}
}
}
void RefreshCommandExecuted(object sender, ExecutedRoutedEventArgs e)

15
ILSpy/Properties/Resources.Designer.cs generated

@ -1605,6 +1605,21 @@ namespace ICSharpCode.ILSpy.Properties { @@ -1605,6 +1605,21 @@ namespace ICSharpCode.ILSpy.Properties {
}
}
/// <summary>
/// Looks up a localized string similar to You are trying to open a single-file executable (app bundle). In order to work with this type of program, ILSpy will
///
///(i) show you a dialog to select a folder to extract the bundle to
///(ii) extract the assemblies (might take a few seconds)
///(iii) show you a dialog to select one or more of those extracted assemblies to decompile
///
///Do you want to proceed?.
/// </summary>
public static string OpenSelfContainedExecutableMessage {
get {
return ResourceManager.GetString("OpenSelfContainedExecutableMessage", resourceCulture);
}
}
/// <summary>
/// Looks up a localized string similar to Options.
/// </summary>

9
ILSpy/Properties/Resources.resx

@ -867,4 +867,13 @@ Do you want to continue?</value> @@ -867,4 +867,13 @@ Do you want to continue?</value>
<data name="CultureLabel" xml:space="preserve">
<value>Culture</value>
</data>
<data name="OpenSelfContainedExecutableMessage" xml:space="preserve">
<value>You are trying to open a single-file executable (app bundle). In order to work with this type of program, ILSpy will
(i) show you a dialog to select a folder to extract the bundle to
(ii) extract the assemblies (might take a few seconds)
(iii) show you a dialog to select one or more of those extracted assemblies to decompile
Do you want to proceed?</value>
</data>
</root>
Loading…
Cancel
Save