views:

240

answers:

3

I'm debugging a program (VS2008), and I was stepping through lines of code. I came across one line where a delegate function was being called, and I tried to step into it. However, rather than stepping into the method as I expected, the method was bypassed, with the debugger instead stepping into what I assume is a function called by the delegate. In the call stack, the line where I expected the delegate method to be is greyed out with the text [Lightweight Function].

What does the "Lightweight Function" part mean? Is there a way to step into this function?

+6  A: 

I believe a lightweight function refers to a DynamicMethod, i.e. one that is emitted at runtime, used, and then unloaded.

This blog post is related to Iron Python, but the information should be good for any .NET project: Viewing Emitted IL. The author shows you how to use a lower level debugger (windbg.exe) to see these "lightweight functions."

bobbymcr
+2  A: 

Looks like this is a DynamicMethod. See this for some insight.

I'm not sure about stepping into a dynamic method, though.

Anton Gogolev
A: 

Callstack for DynamicMethod (both in Debug and Release mode):

[Lightweight Function]  
[Native to Managed Transition]  
mscorlib.dll!System.Reflection.Emit.DynamicMethod.Invoke(object obj, System.Reflection.BindingFlags invokeAttr, System.Reflection.Binder binder, object[] parameters, System.Globalization.CultureInfo culture) + 0x199 bytes

Pure

[Lightweight Function]

frame can be observed when a delegate to a dynamic method is called.