本文整理汇总了C#中System.Reflection.Assembly.First方法的典型用法代码示例。如果您正苦于以下问题:C# Assembly.First方法的具体用法?C# Assembly.First怎么用?C# Assembly.First使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类System.Reflection.Assembly
的用法示例。
在下文中一共展示了Assembly.First方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Amend
/// <summary>
/// Amends the specified target assembly, optionally using assembly amendments defined in the
/// specified amendment assemblies.
/// </summary>
/// <param name="targetAssembly"></param>
/// <param name="amendmentAssemblies"></param>
internal static void Amend(string targetAssembly, string[] amendmentAssemblies, string[] referenceAssemblies)
{
// Verify the target assembly exists
targetAssembly = Path.GetFullPath(targetAssembly);
if (!File.Exists(targetAssembly))
throw new ArgumentException("The specified target assembly, " + targetAssembly + ", does not exist.");
// Verify the amendment assemblies exist
if (amendmentAssemblies == null)
amendmentAssemblies = new string[0];
for (int i = 0; i < amendmentAssemblies.Length; i++)
{
var path = amendmentAssemblies[i] = Path.GetFullPath(amendmentAssemblies[i]);
if (!File.Exists(path))
throw new ArgumentException("The specified amendment assembly, " + path + ", does not exist.");
}
// Verify that the target has not already been amended
var afterthoughtTracker = targetAssembly + ".afterthought";
if (File.Exists(afterthoughtTracker) && File.GetLastWriteTime(targetAssembly) == File.GetLastWriteTime(afterthoughtTracker))
return;
// Determine the set of target directories and backup locations
var targetWriteTime = File.GetLastWriteTime(targetAssembly);
var backupTargetAssembly = targetAssembly + ".backup";
var targetDirectory = Path.GetDirectoryName(targetAssembly);
File.Delete(backupTargetAssembly);
File.Move(targetAssembly, backupTargetAssembly);
// Build up a set of paths with resolving assemblies
var referencePaths = new Dictionary<string, string>();
foreach (string path in amendmentAssemblies
.Union(referenceAssemblies)
.Union(Directory.GetFiles(targetDirectory).Where(p => p.EndsWith(".dll", StringComparison.OrdinalIgnoreCase) && p != targetAssembly)))
referencePaths[Path.GetFileName(path)] = path;
// Register an assembly resolver to look in assembly directories when resolving assemblies
AppDomain.CurrentDomain.AssemblyResolve += (s, e) =>
{
var assemblyName = new System.Reflection.AssemblyName(e.Name).Name + ".dll";
string referencePath;
if (referencePaths.TryGetValue(assemblyName, out referencePath))
return System.Reflection.Assembly.LoadFrom(referencePath);
return null;
};
// Get the set of amendments to apply from all of the specified assemblies
var assemblies = new System.Reflection.Assembly[] { System.Reflection.Assembly.LoadFrom(backupTargetAssembly) }.Union(amendmentAssemblies.Select(a => System.Reflection.Assembly.LoadFrom(a)));
var amendments = AmendmentAttribute.GetAmendments(assemblies.First(), assemblies.Skip(1).ToArray()).ToList();
// Exit immediately if there are no amendments in the target assemblies
if (amendments.Count == 0)
return;
// Amend the target assembly
Console.Write("Amending " + Path.GetFileName(targetAssembly));
var start = DateTime.Now;
using (var host = new PeReader.DefaultHost())
{
foreach (var referencePath in referencePaths.Select(p => Path.GetDirectoryName(p.Value)).Distinct())
host.AddLibPath(referencePath);
// Load the target assembly
IModule module = host.LoadUnitFrom(backupTargetAssembly) as IModule;
if (module == null || module == Dummy.Module || module == Dummy.Assembly)
throw new ArgumentException(backupTargetAssembly + " is not a PE file containing a CLR assembly, or an error occurred when loading it.");
// Copy the assembly to enable it to be mutated
module = new MetadataDeepCopier(host).Copy(module);
// Load the debug file if it exists
PdbReader pdbReader = null;
var pdbFile = Path.Combine(targetDirectory, Path.GetFileNameWithoutExtension(targetAssembly) + ".pdb");
var backupPdbFile = pdbFile + ".backup";
if (File.Exists(pdbFile))
{
File.Delete(backupPdbFile);
File.Move(pdbFile, backupPdbFile);
using (var pdbStream = File.OpenRead(backupPdbFile))
{
pdbReader = new PdbReader(pdbStream, host);
}
}
// Amend and persist the target assembly
using (pdbReader)
{
// Create and execute a new assembly amender
AssemblyAmender amender = new AssemblyAmender(host, pdbReader, amendments, assemblies);
amender.TargetRuntimeVersion = module.TargetRuntimeVersion;
module = amender.Visit(module);
//.........这里部分代码省略.........
示例2: InvokeSafelyForForms
/// <summary>
/// Invokes the method on the first form if need be
/// </summary>
/// <param name="EvalMethod"></param>
/// <returns>The result of the safe call to EvalMethod</returns>
/// <remarks>
/// As we dont want to require the forms assembly for debugutils to work, we need to do all
/// our calling of Forms functions via reflection. The method handles all that but in return is a ugly, ugly
/// piece of code. We basically do the following snippet but with reflection:
///
/// if(Application.OpenForms.Count > 0)
/// {
/// if(Application.OpenForms[0].InvokeRequired)
/// {
/// return Application.OpenForms[0].Invoke(new Func<object>(() =>
/// Invoke(evalMethod)), new object[] { });
/// }
/// }
/// return EvalMethod.Invoke(null, new object[] { });
///
/// </remarks>
private object InvokeSafelyForForms(Assembly[] assemblies, MethodInfo evalMethod)
{
//obtain a reference to the forms assembly
Assembly formsAssembly = assemblies.First(a => a.GetName().Name == "System.Windows.Forms");
//obtain a reference to the application type
Type applicationType = formsAssembly.GetType("System.Windows.Forms.Application");
//next, look for the openForms Property and get its value
PropertyInfo openFormsPropertyInfo = applicationType.GetProperty("OpenForms");
object openForms = openFormsPropertyInfo.GetValue(null, null);
//We now have a reference to our FormCollection. Next we need to see if it has elements.
//The get_Count method does this for us
MethodInfo countMethod = openForms.GetType().GetMethod("get_Count");
//actually invoke the method and cast to int
int formCount = (int)countMethod.Invoke(openForms, null);
// at this point we basically did
// int formCount = Application.OpenForms.Count
// but with reflection. Next we need to check if there even are any forms.
if (formCount > 0)
{
//as we found forms, we now need a reference to a specific one.
//For now we will always use the first form in the list, as your typical Windows Forms Application
//creates all Forms on the same thread anyways
object openForm = openForms.GetType().GetMethod("get_Item", new Type[] { typeof(int) })
.Invoke(openForms, new object[] { 0 });
//next get the invoke required property, to see if we need to proxy our call
bool invokeRequired = (bool)openForm.GetType().GetProperty("InvokeRequired").GetValue(openForm, null);
if (invokeRequired)
{
//get the invoke method of the form so we can proxy our call to it
MethodInfo invokeMethod = openForm.GetType().GetMethod("Invoke", new Type[] { typeof(Delegate) });
//create an appropriate delegate
Delegate proxy = new Func<object>(() => InvokeUnsafe(evalMethod));
//finally invoke the proxy on the form and return the value
return invokeMethod.Invoke(openForm, new object[] { proxy });
}
}
//we dont need to proxy the call so we can just invoke our method
return InvokeUnsafe(evalMethod);
}