GetComSlotForMethodInfo Method
TOC
Collapse the table of content
Expand the table of content
This documentation is archived and is not being maintained.

Marshal.GetComSlotForMethodInfo Method

Gets the virtual function table (VTBL) slot for a specified System.Reflection.MemberInfo when exposed to COM.

Namespace:  System.Runtime.InteropServices
Assembly:  mscorlib (in mscorlib.dll)

[SecurityPermissionAttribute(SecurityAction.LinkDemand, Flags = SecurityPermissionFlag.UnmanagedCode)]
public static int GetComSlotForMethodInfo(
	MemberInfo m
)

Parameters

m
Type: System.Reflection.MemberInfo

A MemberInfo that represents an interface method.

Return Value

Type: System.Int32
The VTBL (also called v-table) slot m identifier when it is exposed to COM.

ExceptionCondition
ArgumentNullException

The m parameter is null.

ArgumentException

The m parameter is not a MethodInfo object.

-or-

The m parameter is not an interface method.

The zero-based slot number returned by this method accounts for three IUnknown and possibly four IDispatch methods, making the value of the first available slot either 3 or 7. GetComSlotForMethodInfo provides the opposite functionality of Marshal.GetMethodInfoForComSlot.

You can use this method to retrieve slot numbers for members of interfaces not visible from COM and for members of private interfaces. The slot numbers returned correspond to the v-table numbers that would be reserved if the type was exposed to COM. COM-invisible members actually occupy a slot in an exposed v-table, even though the COM client cannot use the slot. You cannot use GetComSlotForMethodInfo on a class interface by passing MemberInfo from a class. For additional information on class interfaces, see Introducing the Class Interface.

NoteNote:

This method uses SecurityAction.LinkDemand to prevent it from being called from untrusted code; only the immediate caller is required to have SecurityPermissionAttribute.UnmanagedCode permission. If your code can be called from partially trusted code, do not pass user input to Marshal class methods without validation. For important limitations on using the LinkDemand member, see Demand vs. LinkDemand.

Windows 7, Windows Vista, Windows XP SP2, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP Starter Edition, Windows Server 2008 R2, Windows Server 2008, Windows Server 2003, Windows Server 2000 SP4, Windows Millennium Edition, Windows 98

The .NET Framework and .NET Compact Framework do not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.

.NET Framework

Supported in: 3.5, 3.0, 2.0, 1.1, 1.0
Show:
© 2016 Microsoft