mirror of https://github.com/icsharpcode/ILSpy.git
3 changed files with 141 additions and 248 deletions
@ -1,87 +0,0 @@
@@ -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 @@
@@ -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