Я думаю, что вы ищете, это пользовательский распознаватель сборки. Мне пришлось использовать один, чтобы сделать то, что, как я думаю, вы пытаетесь сделать - я хотел найти некоторые библиотеки DLL в папке, которой не было в дереве исходной неуправляемой библиотеки DLL (которая в конечном итоге загружала управляемый код). *
Шаг 1 состоит в создании функции, которую вы можете вызвать для настройки распознавателя:
void PrepareManagedCode()
{
// Set up our resolver for assembly loading
AppDomain^ currentDomain = AppDomain::CurrentDomain;
currentDomain->AssemblyResolve += gcnew ResolveEventHandler(currentDomain_AssemblyResolve);
} // PrepareManagedCode()
Тогда резольвер. В этом примере есть глобальный ourFinalPath, который в вашем случае будет дополнительной папкой, которую вы использовали:
/// <summary>
/// This handler is called only when the CLR tries to bind to the assembly and fails
/// </summary>
/// <param name="sender">Event originator</param>
/// <param name="args">Event data</param>
/// <returns>The loaded assembly</returns>
Assembly^ currentDomain_AssemblyResolve(Object^ sender, ResolveEventArgs^ args)
{
sender;
// If this is an mscorlib, do a bare load
if (args->Name->Length >= 8 && args->Name->Substring(0, 8) == L"mscorlib")
{
return Assembly::Load(args->Name->Substring(0, args->Name->IndexOf(L",")) + L".dll");
}
// Load the assembly from the specified path
String^ finalPath = nullptr;
try
{
finalPath = gcnew String(ourAssemblyPath) + args->Name->Substring(0, args->Name->IndexOf(",")) + ".dll";
Assembly^ retval = Assembly::LoadFrom(finalPath);
return retval;
}
catch (...)
{
}
return nullptr;
}