I have a .net core 2.0 console app that does the following (simplified):
var a = Assembly.Load(Assembly.GetEntryAssembly()
.GetRefe
You code will not compile if you use Assembly.LoadFile
way.
I'have created a sample project in Visual studio 2017 community and I was able to step into a function from dynamic assembly by using both Assembly.LoadFile
and Assembly.Load
ways. I did not go with you code since it was not compiling, but i will provide a solution which i think you will solve your problem.
Here is the solution: Full working solution is here https://github.com/beyazc/.netcore-dynamic-assembly-debug
Basicly I was able yo debug with following code. You should press f11 on invoke method
var assemlies = Assembly.GetEntryAssembly().GetReferencedAssemblies();
var assemblyName = "";
foreach (var item in assemlies)
{
if (item.Name == "RefProj")
assemblyName = item.Name;
}
var path = new FileInfo(Assembly.GetExecutingAssembly().Location);
var a = Assembly.LoadFile(Path.Combine($@"{path}\..\..\..\..\..\RefProj\bin\Debug\netstandard2.0", "RefProj.dll"));
var t = a.GetType("RefProj.Class1");
var i = Activator.CreateInstance(t);
MethodInfo mi = t.GetMethod("get1");
mi.Invoke(i, null);
This may be caused by the application not being able to locate PDB file associated with MyAssembly
assembly, as mentioned in one of the comments. However, it seems that the PDB file is not required in the same folder as the assembly to make debugging work.
In order to check if symbols are loaded, please put a breakpoint in the line just after calling Assembly.LoadFile()
and open Modules window (it can be found in Debug\Windows menu in Visual Studio). In this window, find the MyAssembly
assembly and verify value in Symbol Status column. If missing PDB is the cause, the value will be "Cannot find or open the PDB file.". You can also use that window to see where debugger tried to find the symbols file.
Debugger looks for the PDB files in several locations, as described here: Specify Symbol (.pdb) and Source Files in the Visual Studio Debugger.
According to the article, the default locations for a PDB file are:
I suppose that in Your case, the first or the second location mentioned should be considered.
Another important thing to notice is that the PDB must exactly match the assembly, so after recompiling the assembly the PDB file should also be updated to match the new version.
If the PDB file matches the assembly and resides in one of the mentioned locations, You should be able to debug the code.
There may be other causes and this is not directly associated with the fact that .NET Core is used, but I suppose that correct PDB loading may be worth verifying.
There is an 'Assembly.Load' override that takes PDB data as a parameter. You need to explicitly load the debug symbols.
Check this SO post: Debug dynamically loaded assembly
Also check out this on MSDN: https://msdn.microsoft.com/en-us/library/twt16z2x(v=vs.110).aspx
Hope this helps
Did you check option just my code?
Enable Just My Code
("My Code") only, ignoring system code and other code that is optimized or that does not have debugging symbols.The debugger displays and steps into user code
Maybe it should be unchecked?
I agree with the answers of Lukasz and Alexan. If you've checked those and it does not work then the reason why your code examples differ could be that they do not load the same assembly.
The executing assembly and entry assembly are not always the same assembly, so the paths can be different. It might also be that another version of the assembly is loaded, for instance from the GAC. Using the modules window in Visual Studio you can see which dll is loaded. If the correct PDB is present and Just My Code is turned off you should be able to step into it.