
3 changed files with 141 additions and 248 deletions
-
87ICSharpCode.Decompiler.Console/CustomAssemblyResolver.cs
-
255ICSharpCode.Decompiler.Console/Program.cs
-
47ICSharpCode.Decompiler.Console/TypesParser.cs
@ -1,87 +0,0 @@ |
|||
using System; |
|||
using System.Collections.Generic; |
|||
using System.IO; |
|||
using Mono.Cecil; |
|||
|
|||
namespace ICSharpCode.Decompiler.Console |
|||
{ |
|||
class CustomAssemblyResolver : DefaultAssemblyResolver |
|||
{ |
|||
DotNetCorePathFinder dotNetCorePathFinder; |
|||
readonly string assemblyFileName; |
|||
readonly Dictionary<string, UnresolvedAssemblyNameReference> loadedAssemblyReferences; |
|||
|
|||
public string TargetFramework { get; set; } |
|||
|
|||
public CustomAssemblyResolver(string fileName) |
|||
{ |
|||
this.assemblyFileName = fileName; |
|||
this.loadedAssemblyReferences = new Dictionary<string, UnresolvedAssemblyNameReference>(); |
|||
AddSearchDirectory(Path.GetDirectoryName(fileName)); |
|||
RemoveSearchDirectory("."); |
|||
} |
|||
|
|||
public override AssemblyDefinition Resolve(AssemblyNameReference name) |
|||
{ |
|||
var targetFramework = TargetFramework.Split(new[] { ",Version=v" }, StringSplitOptions.None); |
|||
string file = null; |
|||
switch (targetFramework[0]) { |
|||
case ".NETCoreApp": |
|||
case ".NETStandard": |
|||
if (targetFramework.Length != 2) goto default; |
|||
if (dotNetCorePathFinder == null) { |
|||
var version = targetFramework[1].Length == 3 ? targetFramework[1] + ".0" : targetFramework[1]; |
|||
dotNetCorePathFinder = new DotNetCorePathFinder(assemblyFileName, TargetFramework, version, this.loadedAssemblyReferences); |
|||
} |
|||
file = dotNetCorePathFinder.TryResolveDotNetCore(name); |
|||
if (file == null) { |
|||
string dir = Path.GetDirectoryName(assemblyFileName); |
|||
if (File.Exists(Path.Combine(dir, name.Name + ".dll"))) |
|||
file = Path.Combine(dir, name.Name + ".dll"); |
|||
else if (File.Exists(Path.Combine(dir, name.Name + ".exe"))) |
|||
file = Path.Combine(dir, name.Name + ".exe"); |
|||
} |
|||
if (file == null) |
|||
return base.Resolve(name); |
|||
else |
|||
return ModuleDefinition.ReadModule(file, new ReaderParameters() { AssemblyResolver = this }).Assembly; |
|||
default: |
|||
return base.Resolve(name); |
|||
} |
|||
} |
|||
|
|||
public override AssemblyDefinition Resolve(AssemblyNameReference name, ReaderParameters parameters) |
|||
{ |
|||
try { |
|||
var targetFramework = TargetFramework.Split(new[] { ",Version=v" }, StringSplitOptions.None); |
|||
string file = null; |
|||
switch (targetFramework[0]) { |
|||
case ".NETCoreApp": |
|||
case ".NETStandard": |
|||
if (targetFramework.Length != 2) goto default; |
|||
if (dotNetCorePathFinder == null) { |
|||
var version = targetFramework[1].Length == 3 ? targetFramework[1] + ".0" : targetFramework[1]; |
|||
dotNetCorePathFinder = new DotNetCorePathFinder(assemblyFileName, TargetFramework, version, this.loadedAssemblyReferences); |
|||
} |
|||
file = dotNetCorePathFinder.TryResolveDotNetCore(name); |
|||
if (file == null) { |
|||
string dir = Path.GetDirectoryName(assemblyFileName); |
|||
if (File.Exists(Path.Combine(dir, name.Name + ".dll"))) |
|||
file = Path.Combine(dir, name.Name + ".dll"); |
|||
else if (File.Exists(Path.Combine(dir, name.Name + ".exe"))) |
|||
file = Path.Combine(dir, name.Name + ".exe"); |
|||
} |
|||
if (file == null) |
|||
return base.Resolve(name, parameters); |
|||
else |
|||
return ModuleDefinition.ReadModule(file, parameters).Assembly; |
|||
default: |
|||
return base.Resolve(name, parameters); |
|||
} |
|||
} catch (AssemblyResolutionException exception) { |
|||
System.Console.WriteLine(exception.ToString()); |
|||
return null; |
|||
} |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,47 @@ |
|||
using System; |
|||
using System.Collections.Generic; |
|||
using System.Linq; |
|||
using System.Text; |
|||
using ICSharpCode.Decompiler.TypeSystem; |
|||
|
|||
namespace ICSharpCode.Decompiler.Console |
|||
{ |
|||
public static class TypesParser |
|||
{ |
|||
public static HashSet<TypeKind> ParseSelection(string[] values) |
|||
{ |
|||
var possibleValues = new Dictionary<string, TypeKind>(StringComparer.OrdinalIgnoreCase) { ["class"] = TypeKind.Class, ["struct"] = TypeKind.Struct, ["interface"] = TypeKind.Interface, ["enum"] = TypeKind.Enum, ["delegate"] = TypeKind.Delegate }; |
|||
HashSet<TypeKind> kinds = new HashSet<TypeKind>(); |
|||
if (values.Length == 1 && !possibleValues.Keys.Any(v => values[0].StartsWith(v, StringComparison.OrdinalIgnoreCase))) { |
|||
foreach (char ch in values[0]) { |
|||
switch (ch) { |
|||
case 'c': |
|||
kinds.Add(TypeKind.Class); |
|||
break; |
|||
case 'i': |
|||
kinds.Add(TypeKind.Interface); |
|||
break; |
|||
case 's': |
|||
kinds.Add(TypeKind.Struct); |
|||
break; |
|||
case 'd': |
|||
kinds.Add(TypeKind.Delegate); |
|||
break; |
|||
case 'e': |
|||
kinds.Add(TypeKind.Enum); |
|||
break; |
|||
} |
|||
} |
|||
} else { |
|||
foreach (var value in values) { |
|||
string v = value; |
|||
while (v.Length > 0 && !possibleValues.ContainsKey(v)) |
|||
v = v.Remove(v.Length - 1); |
|||
if (possibleValues.TryGetValue(v, out var kind)) |
|||
kinds.Add(kind); |
|||
} |
|||
} |
|||
return kinds; |
|||
} |
|||
} |
|||
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue