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

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- RefreshPropertiesAttribute.cs
- DesignTimeVisibleAttribute.cs
- DataListCommandEventArgs.cs
- NodeInfo.cs
- IItemProperties.cs
- Privilege.cs
- HtmlUtf8RawTextWriter.cs
- BrowserInteropHelper.cs
- XmlCharCheckingWriter.cs
- ConnectionProviderAttribute.cs
- TextInfo.cs
- TextSelectionHelper.cs
- DiscreteKeyFrames.cs
- CodeParameterDeclarationExpression.cs
- WindowsPrincipal.cs
- TriggerActionCollection.cs
- PenContext.cs
- PackagePartCollection.cs
- TextCompositionEventArgs.cs
- AdjustableArrowCap.cs
- NavigationHelper.cs
- Exceptions.cs
- DataFieldConverter.cs
- Ref.cs
- ExceptionRoutedEventArgs.cs
- PathGeometry.cs
- FormsAuthenticationConfiguration.cs
- JsonFormatWriterGenerator.cs
- CodeCommentStatementCollection.cs
- Command.cs
- InputScope.cs
- InteropEnvironment.cs
- FileReservationCollection.cs
- ListenerServiceInstallComponent.cs
- SessionEndingCancelEventArgs.cs
- InputElement.cs
- Stylesheet.cs
- DataTableReader.cs
- QueryCacheKey.cs
- InputQueue.cs
- ApplicationActivator.cs
- CompressEmulationStream.cs
- Slider.cs
- SchemaAttDef.cs
- KnownIds.cs
- __ConsoleStream.cs
- WizardStepBase.cs
- Type.cs
- SegmentInfo.cs
- WindowsNonControl.cs
- HostnameComparisonMode.cs
- MatrixAnimationBase.cs
- EntityContainerEmitter.cs
- EditCommandColumn.cs
- CredentialSelector.cs
- StrokeNodeOperations.cs
- LiteralDesigner.cs
- DecimalStorage.cs
- ActivityXamlServices.cs
- AutomationIdentifier.cs
- LeaseManager.cs
- SmiSettersStream.cs
- XmlNodeReader.cs
- DBConcurrencyException.cs
- XPathScanner.cs
- SamlConstants.cs
- XXXOnTypeBuilderInstantiation.cs
- PlatformCulture.cs
- OperationPerformanceCounters.cs
- PathBox.cs
- PointLightBase.cs
- UTF32Encoding.cs
- CategoryNameCollection.cs
- ToolStripItemEventArgs.cs
- XamlStream.cs
- DateTimeStorage.cs
- IOThreadTimer.cs
- SiteMapDataSource.cs
- BindingBase.cs
- SourceFileBuildProvider.cs
- GeneralTransform2DTo3D.cs
- IntegerValidator.cs
- RSACryptoServiceProvider.cs
- DateTimeFormatInfoScanner.cs
- Interlocked.cs
- ReadWriteObjectLock.cs
- SourceSwitch.cs
- BitmapSourceSafeMILHandle.cs
- SecurityAlgorithmSuite.cs
- ListenerConnectionModeReader.cs
- WindowsTab.cs
- DelegateSerializationHolder.cs
- ValueExpressions.cs
- AuthenticationModulesSection.cs
- InputDevice.cs
- DropShadowBitmapEffect.cs
- InstanceHandleReference.cs
- XmlILModule.cs
- ScriptingProfileServiceSection.cs
- StaticExtension.cs