Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / clr / src / BCL / Microsoft / Win32 / FusionWrap.cs / 1305376 / FusionWrap.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== //-------------------------------------------------------------- // FusionInterfaces.cs // // This implements wrappers to Fusion interfaces //------------------------------------------------------------- namespace Microsoft.Win32 { using System; using System.IO; using System.Collections; using System.Runtime.InteropServices; using System.Runtime.CompilerServices; using System.Globalization; using StringBuilder = System.Text.StringBuilder; #if !FEATURE_COMINTEROP using Microsoft.Win32.SafeHandles; #endif // !FEATURE_COMINTEROP #if FEATURE_COMINTEROP //------------------------------------------------------------- // Interfaces defined by fusion //------------------------------------------------------------- [ComImport, InterfaceType(ComInterfaceType.InterfaceIsIUnknown), Guid("21b8916c-f28e-11d2-a473-00c04f8ef448")] interface IAssemblyEnum { [PreserveSig()] int GetNextAssembly(out IApplicationContext ppAppCtx, out IAssemblyName ppName, uint dwFlags); [PreserveSig()] int Reset(); [PreserveSig()] int Clone(out IAssemblyEnum ppEnum); } [ComImport,InterfaceType(ComInterfaceType.InterfaceIsIUnknown), Guid("7c23ff90-33af-11d3-95da-00a024a85b51")] interface IApplicationContext { void SetContextNameObject(IAssemblyName pName); void GetContextNameObject(out IAssemblyName ppName); void Set([MarshalAs(UnmanagedType.LPWStr)] String szName, int pvValue, uint cbValue, uint dwFlags); void Get([MarshalAs(UnmanagedType.LPWStr)] String szName, out int pvValue, ref uint pcbValue, uint dwFlags); void GetDynamicDirectory(out int wzDynamicDir, ref uint pdwSize); } [ComImport, InterfaceType(ComInterfaceType.InterfaceIsIUnknown), Guid("CD193BC0-B4BC-11d2-9833-00C04FC31D2E")] interface IAssemblyName { [PreserveSig()] int SetProperty(uint PropertyId, IntPtr pvProperty, uint cbProperty); [PreserveSig()] int GetProperty(uint PropertyId, IntPtr pvProperty, ref uint pcbProperty); [PreserveSig()] int Finalize(); [PreserveSig()] int GetDisplayName(IntPtr szDisplayName, ref uint pccDisplayName, uint dwDisplayFlags); [PreserveSig()] int BindToObject(Object /*REFIID*/ refIID, Object /*IAssemblyBindSink*/ pAsmBindSink, IApplicationContext pApplicationContext, [MarshalAs(UnmanagedType.LPWStr)] String szCodeBase, Int64 llFlags, int pvReserved, uint cbReserved, out int ppv); [PreserveSig()] int GetName(out uint lpcwBuffer, out int pwzName); [PreserveSig()] int GetVersion(out uint pdwVersionHi, out uint pdwVersionLow); [PreserveSig()] int IsEqual(IAssemblyName pName, uint dwCmpFlags); [PreserveSig()] int Clone(out IAssemblyName pName); } #endif // FEATURE_COMINTEROP internal static class ASM_CACHE { public const uint ZAP = 0x1; public const uint GAC = 0x2; public const uint DOWNLOAD = 0x4; } internal static class CANOF { public const uint PARSE_DISPLAY_NAME = 0x1; public const uint SET_DEFAULT_VALUES = 0x2; } internal static class ASM_NAME { public const uint PUBLIC_KEY = 0; public const uint PUBLIC_KEY_TOKEN = PUBLIC_KEY + 1; public const uint HASH_VALUE = PUBLIC_KEY_TOKEN + 1; public const uint NAME = HASH_VALUE + 1; public const uint MAJOR_VERSION = NAME + 1; public const uint MINOR_VERSION = MAJOR_VERSION + 1; public const uint BUILD_NUMBER = MINOR_VERSION + 1; public const uint REVISION_NUMBER = BUILD_NUMBER + 1; public const uint CULTURE = REVISION_NUMBER + 1; public const uint PROCESSOR_ID_ARRAY = CULTURE + 1; public const uint OSINFO_ARRAY = PROCESSOR_ID_ARRAY + 1; public const uint HASH_ALGID = OSINFO_ARRAY + 1; public const uint ALIAS = HASH_ALGID + 1; public const uint CODEBASE_URL = ALIAS + 1; public const uint CODEBASE_LASTMOD = CODEBASE_URL + 1; public const uint NULL_PUBLIC_KEY = CODEBASE_LASTMOD + 1; public const uint NULL_PUBLIC_KEY_TOKEN = NULL_PUBLIC_KEY + 1; public const uint CUSTOM = NULL_PUBLIC_KEY_TOKEN + 1; public const uint NULL_CUSTOM = CUSTOM + 1; public const uint MVID = NULL_CUSTOM + 1; public const uint _32_BIT_ONLY = MVID + 1; public const uint MAX_PARAMS = _32_BIT_ONLY + 1; } #if FEATURE_FUSION internal static class Fusion { [System.Security.SecurityCritical] // auto-generated public static void ReadCache(ArrayList alAssems, String name, uint nFlag) { #if FEATURE_COMINTEROP IAssemblyEnum aEnum = null; IAssemblyName aName = null; IAssemblyName aNameEnum = null; IApplicationContext AppCtx = null; #else // FEATURE_COMINTEROP SafeFusionHandle aEnum = null; SafeFusionHandle aNameEnum = null; SafeFusionHandle AppCtx = SafeFusionHandle.InvalidHandle; #endif // FEATURE_COMINTEROP int hr; if (name != null) { hr = Win32Native.CreateAssemblyNameObject(out aNameEnum, name, CANOF.PARSE_DISPLAY_NAME, IntPtr.Zero); if (hr != 0) Marshal.ThrowExceptionForHR(hr); } #if !FEATURE_COMINTEROP using (aNameEnum) #endif // !FEATURE_COMINTEROP { hr = Win32Native.CreateAssemblyEnum(out aEnum, AppCtx, aNameEnum, nFlag, IntPtr.Zero); if (hr != 0) Marshal.ThrowExceptionForHR(hr); #if !FEATURE_COMINTEROP using (aEnum) #endif // !FEATURE_COMINTEROP { for (;;) { #if !FEATURE_COMINTEROP using (SafeFusionHandle aAppCtx = new SafeFusionHandle(), aName = new SafeFusionHandle()) #endif // !FEATURE_COMINTEROP { #if FEATURE_COMINTEROP hr = aEnum.GetNextAssembly(out AppCtx, out aName, 0); if (hr != 0) { if (hr < 0) Marshal.ThrowExceptionForHR(hr); break; } #else if (!GetNextAssembly(aEnum, aAppCtx, aName, 0)) break; #endif String sDisplayName = GetDisplayName(aName, 0); if (sDisplayName == null) continue; alAssems.Add(sDisplayName); } // using (aAppCtx, aName) } // for (;;) } // using (aEnum) } // using (aNameEnum) } #if FEATURE_COMINTEROP [System.Security.SecuritySafeCritical] // auto-generated static unsafe String GetDisplayName(IAssemblyName aName, uint dwDisplayFlags) { uint iLen=0; String sDisplayName = null; aName.GetDisplayName((IntPtr)0, ref iLen, dwDisplayFlags); if (iLen > 0) { IntPtr pDisplayName=(IntPtr)0; // Do some memory allocating here // We need to assume that a wide character is 2 bytes. byte[] data = new byte[((int)iLen+1)*2]; fixed (byte *dataptr = data) { pDisplayName = new IntPtr((void *) dataptr); aName.GetDisplayName(pDisplayName, ref iLen, dwDisplayFlags); sDisplayName = Marshal.PtrToStringUni(pDisplayName); } } return sDisplayName; } #else // FEATURE_COMINTEROP [MethodImplAttribute(MethodImplOptions.InternalCall)] static extern bool GetNextAssembly(SafeFusionHandle pEnum, SafeFusionHandle pAppCtx, SafeFusionHandle pName, uint dwFlags); [MethodImplAttribute(MethodImplOptions.InternalCall)] static extern String GetDisplayName(SafeFusionHandle pName, uint dwDisplayFlags); #endif // FEATURE_COMINTEROP } #endif // FEATURE_FUSION } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== //-------------------------------------------------------------- // FusionInterfaces.cs // // This implements wrappers to Fusion interfaces //------------------------------------------------------------- namespace Microsoft.Win32 { using System; using System.IO; using System.Collections; using System.Runtime.InteropServices; using System.Runtime.CompilerServices; using System.Globalization; using StringBuilder = System.Text.StringBuilder; #if !FEATURE_COMINTEROP using Microsoft.Win32.SafeHandles; #endif // !FEATURE_COMINTEROP #if FEATURE_COMINTEROP //------------------------------------------------------------- // Interfaces defined by fusion //------------------------------------------------------------- [ComImport, InterfaceType(ComInterfaceType.InterfaceIsIUnknown), Guid("21b8916c-f28e-11d2-a473-00c04f8ef448")] interface IAssemblyEnum { [PreserveSig()] int GetNextAssembly(out IApplicationContext ppAppCtx, out IAssemblyName ppName, uint dwFlags); [PreserveSig()] int Reset(); [PreserveSig()] int Clone(out IAssemblyEnum ppEnum); } [ComImport,InterfaceType(ComInterfaceType.InterfaceIsIUnknown), Guid("7c23ff90-33af-11d3-95da-00a024a85b51")] interface IApplicationContext { void SetContextNameObject(IAssemblyName pName); void GetContextNameObject(out IAssemblyName ppName); void Set([MarshalAs(UnmanagedType.LPWStr)] String szName, int pvValue, uint cbValue, uint dwFlags); void Get([MarshalAs(UnmanagedType.LPWStr)] String szName, out int pvValue, ref uint pcbValue, uint dwFlags); void GetDynamicDirectory(out int wzDynamicDir, ref uint pdwSize); } [ComImport, InterfaceType(ComInterfaceType.InterfaceIsIUnknown), Guid("CD193BC0-B4BC-11d2-9833-00C04FC31D2E")] interface IAssemblyName { [PreserveSig()] int SetProperty(uint PropertyId, IntPtr pvProperty, uint cbProperty); [PreserveSig()] int GetProperty(uint PropertyId, IntPtr pvProperty, ref uint pcbProperty); [PreserveSig()] int Finalize(); [PreserveSig()] int GetDisplayName(IntPtr szDisplayName, ref uint pccDisplayName, uint dwDisplayFlags); [PreserveSig()] int BindToObject(Object /*REFIID*/ refIID, Object /*IAssemblyBindSink*/ pAsmBindSink, IApplicationContext pApplicationContext, [MarshalAs(UnmanagedType.LPWStr)] String szCodeBase, Int64 llFlags, int pvReserved, uint cbReserved, out int ppv); [PreserveSig()] int GetName(out uint lpcwBuffer, out int pwzName); [PreserveSig()] int GetVersion(out uint pdwVersionHi, out uint pdwVersionLow); [PreserveSig()] int IsEqual(IAssemblyName pName, uint dwCmpFlags); [PreserveSig()] int Clone(out IAssemblyName pName); } #endif // FEATURE_COMINTEROP internal static class ASM_CACHE { public const uint ZAP = 0x1; public const uint GAC = 0x2; public const uint DOWNLOAD = 0x4; } internal static class CANOF { public const uint PARSE_DISPLAY_NAME = 0x1; public const uint SET_DEFAULT_VALUES = 0x2; } internal static class ASM_NAME { public const uint PUBLIC_KEY = 0; public const uint PUBLIC_KEY_TOKEN = PUBLIC_KEY + 1; public const uint HASH_VALUE = PUBLIC_KEY_TOKEN + 1; public const uint NAME = HASH_VALUE + 1; public const uint MAJOR_VERSION = NAME + 1; public const uint MINOR_VERSION = MAJOR_VERSION + 1; public const uint BUILD_NUMBER = MINOR_VERSION + 1; public const uint REVISION_NUMBER = BUILD_NUMBER + 1; public const uint CULTURE = REVISION_NUMBER + 1; public const uint PROCESSOR_ID_ARRAY = CULTURE + 1; public const uint OSINFO_ARRAY = PROCESSOR_ID_ARRAY + 1; public const uint HASH_ALGID = OSINFO_ARRAY + 1; public const uint ALIAS = HASH_ALGID + 1; public const uint CODEBASE_URL = ALIAS + 1; public const uint CODEBASE_LASTMOD = CODEBASE_URL + 1; public const uint NULL_PUBLIC_KEY = CODEBASE_LASTMOD + 1; public const uint NULL_PUBLIC_KEY_TOKEN = NULL_PUBLIC_KEY + 1; public const uint CUSTOM = NULL_PUBLIC_KEY_TOKEN + 1; public const uint NULL_CUSTOM = CUSTOM + 1; public const uint MVID = NULL_CUSTOM + 1; public const uint _32_BIT_ONLY = MVID + 1; public const uint MAX_PARAMS = _32_BIT_ONLY + 1; } #if FEATURE_FUSION internal static class Fusion { [System.Security.SecurityCritical] // auto-generated public static void ReadCache(ArrayList alAssems, String name, uint nFlag) { #if FEATURE_COMINTEROP IAssemblyEnum aEnum = null; IAssemblyName aName = null; IAssemblyName aNameEnum = null; IApplicationContext AppCtx = null; #else // FEATURE_COMINTEROP SafeFusionHandle aEnum = null; SafeFusionHandle aNameEnum = null; SafeFusionHandle AppCtx = SafeFusionHandle.InvalidHandle; #endif // FEATURE_COMINTEROP int hr; if (name != null) { hr = Win32Native.CreateAssemblyNameObject(out aNameEnum, name, CANOF.PARSE_DISPLAY_NAME, IntPtr.Zero); if (hr != 0) Marshal.ThrowExceptionForHR(hr); } #if !FEATURE_COMINTEROP using (aNameEnum) #endif // !FEATURE_COMINTEROP { hr = Win32Native.CreateAssemblyEnum(out aEnum, AppCtx, aNameEnum, nFlag, IntPtr.Zero); if (hr != 0) Marshal.ThrowExceptionForHR(hr); #if !FEATURE_COMINTEROP using (aEnum) #endif // !FEATURE_COMINTEROP { for (;;) { #if !FEATURE_COMINTEROP using (SafeFusionHandle aAppCtx = new SafeFusionHandle(), aName = new SafeFusionHandle()) #endif // !FEATURE_COMINTEROP { #if FEATURE_COMINTEROP hr = aEnum.GetNextAssembly(out AppCtx, out aName, 0); if (hr != 0) { if (hr < 0) Marshal.ThrowExceptionForHR(hr); break; } #else if (!GetNextAssembly(aEnum, aAppCtx, aName, 0)) break; #endif String sDisplayName = GetDisplayName(aName, 0); if (sDisplayName == null) continue; alAssems.Add(sDisplayName); } // using (aAppCtx, aName) } // for (;;) } // using (aEnum) } // using (aNameEnum) } #if FEATURE_COMINTEROP [System.Security.SecuritySafeCritical] // auto-generated static unsafe String GetDisplayName(IAssemblyName aName, uint dwDisplayFlags) { uint iLen=0; String sDisplayName = null; aName.GetDisplayName((IntPtr)0, ref iLen, dwDisplayFlags); if (iLen > 0) { IntPtr pDisplayName=(IntPtr)0; // Do some memory allocating here // We need to assume that a wide character is 2 bytes. byte[] data = new byte[((int)iLen+1)*2]; fixed (byte *dataptr = data) { pDisplayName = new IntPtr((void *) dataptr); aName.GetDisplayName(pDisplayName, ref iLen, dwDisplayFlags); sDisplayName = Marshal.PtrToStringUni(pDisplayName); } } return sDisplayName; } #else // FEATURE_COMINTEROP [MethodImplAttribute(MethodImplOptions.InternalCall)] static extern bool GetNextAssembly(SafeFusionHandle pEnum, SafeFusionHandle pAppCtx, SafeFusionHandle pName, uint dwFlags); [MethodImplAttribute(MethodImplOptions.InternalCall)] static extern String GetDisplayName(SafeFusionHandle pName, uint dwDisplayFlags); #endif // FEATURE_COMINTEROP } #endif // FEATURE_FUSION } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
![Network programming in C#, Network Programming in VB.NET, Network Programming in .NET](/images/book.jpg)
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- RectangleGeometry.cs
- HtmlWindowCollection.cs
- SecurityTokenResolver.cs
- SafeArrayTypeMismatchException.cs
- BindToObject.cs
- DataRelationCollection.cs
- Floater.cs
- BindingManagerDataErrorEventArgs.cs
- PenThreadPool.cs
- X500Name.cs
- DataListCommandEventArgs.cs
- SHA384.cs
- ToolStripOverflow.cs
- ProgressBarAutomationPeer.cs
- XmlSchemaSimpleTypeUnion.cs
- UserPersonalizationStateInfo.cs
- XsdDuration.cs
- ClientSideQueueItem.cs
- WebPartDescription.cs
- Style.cs
- Ipv6Element.cs
- PrintDialogException.cs
- MonthChangedEventArgs.cs
- DataGridViewAutoSizeModeEventArgs.cs
- TransportChannelFactory.cs
- securitycriticaldataClass.cs
- DataTableReader.cs
- HttpCacheParams.cs
- BodyWriter.cs
- ZipIOExtraFieldElement.cs
- XmlComplianceUtil.cs
- AspCompat.cs
- TextBoxView.cs
- PerformanceCounterLib.cs
- LinqDataSourceEditData.cs
- SourceElementsCollection.cs
- CroppedBitmap.cs
- ForwardPositionQuery.cs
- SqlMethodAttribute.cs
- SpellerHighlightLayer.cs
- Property.cs
- DisplayInformation.cs
- UIElement.cs
- CompiledRegexRunner.cs
- BackgroundWorker.cs
- HttpModuleActionCollection.cs
- WebBrowserProgressChangedEventHandler.cs
- SmiRequestExecutor.cs
- ContentElementAutomationPeer.cs
- SecUtil.cs
- WindowsPrincipal.cs
- XsltConvert.cs
- UserNameSecurityToken.cs
- PropertyChangedEventManager.cs
- EventWaitHandleSecurity.cs
- IisTraceWebEventProvider.cs
- coordinator.cs
- EventMappingSettings.cs
- SemanticBasicElement.cs
- HelloMessageApril2005.cs
- ImmComposition.cs
- NavigationHelper.cs
- WinInetCache.cs
- SplayTreeNode.cs
- CustomError.cs
- FontStretch.cs
- WebHttpDispatchOperationSelectorData.cs
- WorkflowIdleBehavior.cs
- CodeDomSerializerException.cs
- SoapEnumAttribute.cs
- SqlTypesSchemaImporter.cs
- WebPartAuthorizationEventArgs.cs
- TransportContext.cs
- MouseButtonEventArgs.cs
- GeneralTransform3DTo2D.cs
- TextElementEnumerator.cs
- CodeSubDirectoriesCollection.cs
- AssemblyInfo.cs
- hresults.cs
- IOException.cs
- BigInt.cs
- ImageCodecInfoPrivate.cs
- EntityDataSourceChangingEventArgs.cs
- ListViewItemEventArgs.cs
- WebResourceUtil.cs
- ContextMenuStrip.cs
- WebServiceHandler.cs
- TextServicesCompartmentContext.cs
- IndependentAnimationStorage.cs
- D3DImage.cs
- ProcessModelInfo.cs
- ReferentialConstraint.cs
- TypeExtensions.cs
- WebPartDisplayModeCollection.cs
- ItemChangedEventArgs.cs
- ToolStripLocationCancelEventArgs.cs
- DateRangeEvent.cs
- DataBoundControlAdapter.cs
- SoapAttributeOverrides.cs
- HttpFormatExtensions.cs