Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

A procedure imported by {myassembly} could not be loaded

when running a prorgam, it seems that I am missing a library, when I launch the output of my project I get an exception at startup.

A first chance exception of type 'System.IO.FileLoadException' occurred in mscorlib.dll
An unhandled exception of type 'System.IO.FileLoadException' occurred in mscorlib.dll

Additional information: A procedure imported by 'my assembly, Version=xx.1.1.0, Culture=neutral, PublicKeyToken=7292581204d9e04a' could not be loaded.

'ScriptX.vshost.exe' (Managed): Loaded 'C:\WINDOWS\assembly\GAC_MSIL\System.Configuration\2.0.0.0__b03f5f7f11d50a3a\System.Configuration.dll', No symbols loaded.

My question is: how can I determine which library is missing because, at this point, I cannot see the values passed to:

mscorlib.dll!System.AppDomain.ExecuteAssembly(string assemblyFile, System.Security.Policy.Evidence assemblySecurity, string[] args) + 0x3a bytes    
like image 653
BlueTrin Avatar asked Dec 22 '09 10:12

BlueTrin


3 Answers

There is in fact a built in mechanism for just these diagnostics.

(1) In your project properties/Debug, make sure 'Enable native code debugging' is checked:

enter image description here

(2) Raise the show-loader-snaps flag - it is a registry key in the IFEO, and is accessible via the 'GlobalFlags' GUI:

enter image description here

(3) Run the app from a debugger - or attach before the load error. Inspect the (very) verbose output pane. You can mostly skip to the end or look for 'ERROR'.

More details here.

like image 132
Ofek Shilon Avatar answered Nov 17 '22 17:11

Ofek Shilon


Are you doing any dllimport? - this looks like an issue with an unmanaged dll not being found?

First thing is to ensure that any unmanaged dll's or exe's that you are calling into (via dllimport) are deployed into the same folder as the .Net exe that you are building

If the source of the calling assembly is not available you could try using reflector on that assembly to search for dllimport statements

Other than that you might want to enable the fustion log viewer to trace assembly load issues - see this blog post and msdn page for more details

like image 26
Richard Avatar answered Nov 17 '22 16:11

Richard


Implement a handler for the AppDomain.AssemblyResolve event. It tells you which assembly it is looking for with ResolveEventArgs.Name. If this is just an effort to troubleshoot this particular assembly then use Fuslogvw.exe. If the hangup is an unmanaged assembly then DependencyWalker's Profile option can show you what LoadLibrary() call is failing. SysInternals' ProcMon will work too but is a lot noisier.

like image 6
Hans Passant Avatar answered Nov 17 '22 18:11

Hans Passant