LCIDConversionAttribute Class
.NET Framework 4.5
Indicates that a method's unmanaged signature expects a locale identifier (LCID) parameter.
Namespace:
System.Runtime.InteropServices
Assembly: mscorlib (in mscorlib.dll)
The LCIDConversionAttribute type exposes the following members.
| Name | Description | |
|---|---|---|
![]() | LCIDConversionAttribute | Initializes a new instance of the LCIDConversionAttribute class with the position of the LCID in the unmanaged signature. |
| Name | Description | |
|---|---|---|
![]() | Equals | Infrastructure. Returns a value that indicates whether this instance is equal to a specified object. (Inherited from Attribute.) |
![]() | GetHashCode | Returns the hash code for this instance. (Inherited from Attribute.) |
![]() | GetType | Gets the Type of the current instance. (Inherited from Object.) |
![]() | IsDefaultAttribute | When overridden in a derived class, indicates whether the value of this instance is the default value for the derived class. (Inherited from Attribute.) |
![]() | Match | When overridden in a derived class, returns a value that indicates whether this instance equals a specified object. (Inherited from Attribute.) |
![]() | ToString | Returns a string that represents the current object. (Inherited from Object.) |
| Name | Description | |
|---|---|---|
![]() ![]() | _Attribute.GetIDsOfNames | Maps a set of names to a corresponding set of dispatch identifiers. (Inherited from Attribute.) |
![]() ![]() | _Attribute.GetTypeInfo | Retrieves the type information for an object, which can be used to get the type information for an interface. (Inherited from Attribute.) |
![]() ![]() | _Attribute.GetTypeInfoCount | Retrieves the number of type information interfaces that an object provides (either 0 or 1). (Inherited from Attribute.) |
![]() ![]() | _Attribute.Invoke | Provides access to properties and methods exposed by an object. (Inherited from Attribute.) |
The following example demonstrates different signature translations based on different values supplied to LCIDConversionAttribute.
using System; using System.Runtime.InteropServices; using System.Reflection; class LCIDAttrSample { private const int LCID_INSTALLED = 1; private const int LCID_SUPPORTED = 2; [DllImport("KERNEL32.DLL", EntryPoint="IsValidLocale", SetLastError = true, CharSet = CharSet.Auto)] [LCIDConversionAttribute(0)] // Position of the LCID argument public static extern bool IsValidLocale( uint dwFlags // options ); public void CheckCurrentLCID() { MethodInfo mthIfo = this.GetType().GetMethod("IsValidLocale"); Attribute attr = Attribute.GetCustomAttribute(mthIfo,typeof(LCIDConversionAttribute)); if( attr != null) { LCIDConversionAttribute lcidAttr = (LCIDConversionAttribute)attr; Console.WriteLine("Position of the LCID argument in the unmanaged signature: " + lcidAttr.Value.ToString()); } bool res = IsValidLocale(LCID_INSTALLED); Console.WriteLine("Result LCID_INSTALLED " + res.ToString()); res = IsValidLocale(LCID_SUPPORTED); Console.WriteLine("Result LCID_SUPPORTED " + res.ToString()); } static void Main(string[] args) { LCIDAttrSample smpl = new LCIDAttrSample(); smpl.CheckCurrentLCID(); } }
Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008 (Server Core Role not supported), Windows Server 2008 R2 (Server Core Role supported with SP1 or later; Itanium not supported)
The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.
