Что я хочу сделать, это изменить способ выполнения С# метода при его вызове, чтобы я мог написать что-то вроде этого:
[Distributed]
public DTask<bool> Solve(int n, DEvent<bool> callback)
{
for (int m = 2; m < n - 1; m += 1)
if (m % n == 0)
return false;
return true;
}
Во время выполнения я должен иметь возможность анализировать методы, которые имеют атрибут Distributed (который я уже могу сделать), а затем вставлять код до того, как тело функции выполнится и после возвращения функции. Что еще более важно, мне нужно иметь возможность сделать это без изменения кода, где вызывается Solve или в начале функции (во время компиляции, это делается во время выполнения).
В настоящий момент я попытался выполнить этот бит кода (предположим, что t - это тип, в котором хранится Solve, а m - MethodInfo of Solve):
private void WrapMethod(Type t, MethodInfo m)
{
// Generate ILasm for delegate.
byte[] il = typeof(Dpm).GetMethod("ReplacedSolve").GetMethodBody().GetILAsByteArray();
// Pin the bytes in the garbage collection.
GCHandle h = GCHandle.Alloc((object)il, GCHandleType.Pinned);
IntPtr addr = h.AddrOfPinnedObject();
int size = il.Length;
// Swap the method.
MethodRental.SwapMethodBody(t, m.MetadataToken, addr, size, MethodRental.JitImmediate);
}
public DTask<bool> ReplacedSolve(int n, DEvent<bool> callback)
{
Console.WriteLine("This was executed instead!");
return true;
}
Однако MethodRental.SwapMethodBody работает только с динамическими модулями; а не те, которые уже были скомпилированы и сохранены в сборке.
Итак, я ищу способ эффективно выполнить SwapMethodBody на методе, который уже сохранен в загруженной и исполняемой сборке.
Обратите внимание: это не проблема, если мне нужно полностью копировать этот метод в динамический модуль, но в этом случае мне нужно найти способ копирования через IL, а также обновить все вызовы Solve() чтобы они указывали на новую копию.