mirror of https://github.com/icsharpcode/ILSpy.git
3 changed files with 141 additions and 248 deletions
@ -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; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
Loading…
Reference in new issue