Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / xsp / System / Web / Util / Misc.cs / 5 / Misc.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.Util { using System.Collections; using System.Globalization; using System.Runtime.InteropServices; using System.Text; using System.Web.Hosting; using Microsoft.Win32; internal sealed class Misc { const string APPLICATION_ID = "\r\n\r\nApplication ID: "; const string PROCESS_ID = "\r\n\r\nProcess ID: "; const string EXCEPTION = "\r\n\r\nException: "; const string INNER_EXCEPTION = "\r\n\r\nInnerException: "; const string MESSAGE = "\r\n\r\nMessage: "; const string STACK_TRACE = "\r\n\r\nStackTrace: "; static StringComparer s_caseInsensitiveInvariantKeyComparer; internal static StringComparer CaseInsensitiveInvariantKeyComparer { get { if (s_caseInsensitiveInvariantKeyComparer == null) { s_caseInsensitiveInvariantKeyComparer = StringComparer.Create(CultureInfo.InvariantCulture, true); } return s_caseInsensitiveInvariantKeyComparer; } } internal static void WriteUnhandledExceptionToEventLog(AppDomain appDomain, Exception exception) { if (appDomain == null || exception == null) { return; } ProcessImpersonationContext imperContext = null; try { imperContext = new ProcessImpersonationContext(); String appId = appDomain.GetData(".appId") as String; if (appId == null) { appId = appDomain.FriendlyName; } string pid = SafeNativeMethods.GetCurrentProcessId().ToString(CultureInfo.InstalledUICulture); string description = SR.Resources.GetString(SR.Unhandled_Exception, CultureInfo.InstalledUICulture); Misc.ReportUnhandledException(exception, new string[5] {description, APPLICATION_ID, appId, PROCESS_ID, pid}); } catch { // ignore exceptions so that WriteErrorToEventLog never throws } finally { if (imperContext != null) { imperContext.Undo(); } } } internal static void ReportUnhandledException(Exception e, String[] strings) { StringBuilder sb = new StringBuilder(4096); for (int i = 0; i < strings.Length; i++) { sb.Append(strings[i]); } for (Exception current = e; current != null; current = current.InnerException) { if (current == e) sb.Append(EXCEPTION); else sb.Append(INNER_EXCEPTION); sb.Append(current.GetType().FullName); sb.Append(MESSAGE); sb.Append(current.Message); sb.Append(STACK_TRACE); sb.Append(current.StackTrace); } UnsafeNativeMethods.ReportUnhandledException(sb.ToString()); } #if UNUSED_CODE static IKeyComparer s_caseSensitiveInvariantKeyComparer; internal static IKeyComparer CaseSensitiveInvariantKeyComparer { get { if (s_caseSensitiveInvariantKeyComparer == null) { s_caseSensitiveInvariantKeyComparer = KeyComparer.CreateKeyComparer(CultureInfo.InvariantCulture, false); } return s_caseSensitiveInvariantKeyComparer; } } #endif internal unsafe static void CopyMemory(IntPtr src, int srcOffset, byte[] dest, int destOffset, int size) { // System.Runtime.InteropServices.Marshal.Copy(new IntPtr(src.ToInt64()+srcOffset), dest, destOffset, size); } internal unsafe static void CopyMemory(byte[] src, int srcOffset, IntPtr dest, int destOffset, int size) { // System.Runtime.InteropServices.Marshal.Copy(src, srcOffset, new IntPtr(dest.ToInt64()+destOffset), size); } internal unsafe static void CopyMemory(IntPtr src, int srcOffset, IntPtr dest, int destOffset, int size) { byte *s = ((byte*)src) + srcOffset; byte *d = ((byte*)dest) + destOffset; StringUtil.memcpyimpl(s, d, size); } internal static void ThrowIfFailedHr(int hresult) { // SUCCEEDED >= 0 // FAILED < 0 if (hresult < 0) { Marshal.ThrowExceptionForHR(hresult); } } internal static IProcessHostSupportFunctions CreateLocalSupportFunctions(IProcessHostSupportFunctions proxyFunctions) { IProcessHostSupportFunctions localFunctions = null; // get the underlying COM object IntPtr pUnk = Marshal.GetIUnknownForObject(proxyFunctions); // this object isn't a COM object if (IntPtr.Zero == pUnk) { return null; } IntPtr ppv = IntPtr.Zero; try { // QI it for the interface Guid g = typeof(IProcessHostSupportFunctions).GUID; int hresult = Marshal.QueryInterface(pUnk, ref g, out ppv); if (hresult < 0) { Marshal.ThrowExceptionForHR(hresult); } // create a RCW we can hold onto in this domain // this bumps the ref count so we can drop our refs on the raw interfaces localFunctions = (IProcessHostSupportFunctions)Marshal.GetObjectForIUnknown(ppv); } finally { // drop our explicit refs and keep the managed instance if (IntPtr.Zero != ppv) { Marshal.Release(ppv); } if (IntPtr.Zero != pUnk) { Marshal.Release(pUnk); } } return localFunctions; } // Open ASP.NET's reg key, or one of its subkeys internal static RegistryKey OpenAspNetRegKey(string subKey) { String ver = VersionInfo.SystemWebVersion; // Zero out minor version number VSWhidbey 602541 // Eg. 2.0.50727.42 becomes 2.0.50727.0 if (!string.IsNullOrEmpty(ver)) { int pos = ver.LastIndexOf('.'); if (pos > -1) { ver = ver.Substring(0, pos + 1) + "0"; } } // The main ASP.NET reg key string key = @"Software\Microsoft\ASP.NET\" + ver; // If we're asked for a subkey, append it if (subKey != null) key += @"\" + subKey; // Open and return the key return Registry.LocalMachine.OpenSubKey(key); } // Get an ASP.NET registry value, from the main key or a subkey internal static object GetAspNetRegValue(string subKey, string valueName, object defaultValue) { try { using (RegistryKey regKey = OpenAspNetRegKey(subKey)) { // Return the default value if the key doesn't exist if (regKey == null) return defaultValue; return regKey.GetValue(valueName, defaultValue); } } catch { // Return the default value if anything goes wrong return defaultValue; } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.Util { using System.Collections; using System.Globalization; using System.Runtime.InteropServices; using System.Text; using System.Web.Hosting; using Microsoft.Win32; internal sealed class Misc { const string APPLICATION_ID = "\r\n\r\nApplication ID: "; const string PROCESS_ID = "\r\n\r\nProcess ID: "; const string EXCEPTION = "\r\n\r\nException: "; const string INNER_EXCEPTION = "\r\n\r\nInnerException: "; const string MESSAGE = "\r\n\r\nMessage: "; const string STACK_TRACE = "\r\n\r\nStackTrace: "; static StringComparer s_caseInsensitiveInvariantKeyComparer; internal static StringComparer CaseInsensitiveInvariantKeyComparer { get { if (s_caseInsensitiveInvariantKeyComparer == null) { s_caseInsensitiveInvariantKeyComparer = StringComparer.Create(CultureInfo.InvariantCulture, true); } return s_caseInsensitiveInvariantKeyComparer; } } internal static void WriteUnhandledExceptionToEventLog(AppDomain appDomain, Exception exception) { if (appDomain == null || exception == null) { return; } ProcessImpersonationContext imperContext = null; try { imperContext = new ProcessImpersonationContext(); String appId = appDomain.GetData(".appId") as String; if (appId == null) { appId = appDomain.FriendlyName; } string pid = SafeNativeMethods.GetCurrentProcessId().ToString(CultureInfo.InstalledUICulture); string description = SR.Resources.GetString(SR.Unhandled_Exception, CultureInfo.InstalledUICulture); Misc.ReportUnhandledException(exception, new string[5] {description, APPLICATION_ID, appId, PROCESS_ID, pid}); } catch { // ignore exceptions so that WriteErrorToEventLog never throws } finally { if (imperContext != null) { imperContext.Undo(); } } } internal static void ReportUnhandledException(Exception e, String[] strings) { StringBuilder sb = new StringBuilder(4096); for (int i = 0; i < strings.Length; i++) { sb.Append(strings[i]); } for (Exception current = e; current != null; current = current.InnerException) { if (current == e) sb.Append(EXCEPTION); else sb.Append(INNER_EXCEPTION); sb.Append(current.GetType().FullName); sb.Append(MESSAGE); sb.Append(current.Message); sb.Append(STACK_TRACE); sb.Append(current.StackTrace); } UnsafeNativeMethods.ReportUnhandledException(sb.ToString()); } #if UNUSED_CODE static IKeyComparer s_caseSensitiveInvariantKeyComparer; internal static IKeyComparer CaseSensitiveInvariantKeyComparer { get { if (s_caseSensitiveInvariantKeyComparer == null) { s_caseSensitiveInvariantKeyComparer = KeyComparer.CreateKeyComparer(CultureInfo.InvariantCulture, false); } return s_caseSensitiveInvariantKeyComparer; } } #endif internal unsafe static void CopyMemory(IntPtr src, int srcOffset, byte[] dest, int destOffset, int size) { // System.Runtime.InteropServices.Marshal.Copy(new IntPtr(src.ToInt64()+srcOffset), dest, destOffset, size); } internal unsafe static void CopyMemory(byte[] src, int srcOffset, IntPtr dest, int destOffset, int size) { // System.Runtime.InteropServices.Marshal.Copy(src, srcOffset, new IntPtr(dest.ToInt64()+destOffset), size); } internal unsafe static void CopyMemory(IntPtr src, int srcOffset, IntPtr dest, int destOffset, int size) { byte *s = ((byte*)src) + srcOffset; byte *d = ((byte*)dest) + destOffset; StringUtil.memcpyimpl(s, d, size); } internal static void ThrowIfFailedHr(int hresult) { // SUCCEEDED >= 0 // FAILED < 0 if (hresult < 0) { Marshal.ThrowExceptionForHR(hresult); } } internal static IProcessHostSupportFunctions CreateLocalSupportFunctions(IProcessHostSupportFunctions proxyFunctions) { IProcessHostSupportFunctions localFunctions = null; // get the underlying COM object IntPtr pUnk = Marshal.GetIUnknownForObject(proxyFunctions); // this object isn't a COM object if (IntPtr.Zero == pUnk) { return null; } IntPtr ppv = IntPtr.Zero; try { // QI it for the interface Guid g = typeof(IProcessHostSupportFunctions).GUID; int hresult = Marshal.QueryInterface(pUnk, ref g, out ppv); if (hresult < 0) { Marshal.ThrowExceptionForHR(hresult); } // create a RCW we can hold onto in this domain // this bumps the ref count so we can drop our refs on the raw interfaces localFunctions = (IProcessHostSupportFunctions)Marshal.GetObjectForIUnknown(ppv); } finally { // drop our explicit refs and keep the managed instance if (IntPtr.Zero != ppv) { Marshal.Release(ppv); } if (IntPtr.Zero != pUnk) { Marshal.Release(pUnk); } } return localFunctions; } // Open ASP.NET's reg key, or one of its subkeys internal static RegistryKey OpenAspNetRegKey(string subKey) { String ver = VersionInfo.SystemWebVersion; // Zero out minor version number VSWhidbey 602541 // Eg. 2.0.50727.42 becomes 2.0.50727.0 if (!string.IsNullOrEmpty(ver)) { int pos = ver.LastIndexOf('.'); if (pos > -1) { ver = ver.Substring(0, pos + 1) + "0"; } } // The main ASP.NET reg key string key = @"Software\Microsoft\ASP.NET\" + ver; // If we're asked for a subkey, append it if (subKey != null) key += @"\" + subKey; // Open and return the key return Registry.LocalMachine.OpenSubKey(key); } // Get an ASP.NET registry value, from the main key or a subkey internal static object GetAspNetRegValue(string subKey, string valueName, object defaultValue) { try { using (RegistryKey regKey = OpenAspNetRegKey(subKey)) { // Return the default value if the key doesn't exist if (regKey == null) return defaultValue; return regKey.GetValue(valueName, defaultValue); } } catch { // Return the default value if anything goes wrong return defaultValue; } } } } // 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
- SynchronizedPool.cs
- EncryptedPackageFilter.cs
- RenderDataDrawingContext.cs
- UIElement3D.cs
- TypedAsyncResult.cs
- ProfileService.cs
- HttpCapabilitiesBase.cs
- MergeFailedEvent.cs
- BulletDecorator.cs
- InstanceDataCollection.cs
- HandleCollector.cs
- Block.cs
- DetailsView.cs
- AppModelKnownContentFactory.cs
- InitializationEventAttribute.cs
- HandleExceptionArgs.cs
- TextBoxRenderer.cs
- coordinatorscratchpad.cs
- ObjectDataSourceMethodEventArgs.cs
- Persist.cs
- ObjectDisposedException.cs
- ArithmeticException.cs
- wgx_render.cs
- DataGridViewRowCollection.cs
- EntityConnectionStringBuilder.cs
- InstallHelper.cs
- LifetimeServices.cs
- DbProviderConfigurationHandler.cs
- PerfCounterSection.cs
- DebuggerAttributes.cs
- ServiceModelSectionGroup.cs
- SecurityContextKeyIdentifierClause.cs
- OrderPreservingSpoolingTask.cs
- XmlHelper.cs
- XmlSchemaInclude.cs
- PixelFormats.cs
- TextSelectionHelper.cs
- DelegatedStream.cs
- BamlLocalizableResource.cs
- FormatException.cs
- MissingFieldException.cs
- RowToFieldTransformer.cs
- QilPatternVisitor.cs
- SkewTransform.cs
- webclient.cs
- InvokePattern.cs
- EarlyBoundInfo.cs
- CalendarDay.cs
- EndpointDiscoveryMetadata.cs
- DynamicDocumentPaginator.cs
- MetaTable.cs
- XmlDataSource.cs
- EventLogHandle.cs
- CurrentTimeZone.cs
- Pen.cs
- XsdBuildProvider.cs
- CapabilitiesAssignment.cs
- FileUpload.cs
- QuaternionValueSerializer.cs
- ContentPresenter.cs
- ConfigurationConverterBase.cs
- StructuredTypeInfo.cs
- CompilerErrorCollection.cs
- DockProviderWrapper.cs
- OdbcDataAdapter.cs
- CodeThrowExceptionStatement.cs
- CursorEditor.cs
- basenumberconverter.cs
- ScriptMethodAttribute.cs
- DispatcherFrame.cs
- PropertyGridCommands.cs
- ProfileEventArgs.cs
- ProcessThreadCollection.cs
- StateMachine.cs
- Schema.cs
- InvalidComObjectException.cs
- DesignerProperties.cs
- BmpBitmapDecoder.cs
- Positioning.cs
- ActionFrame.cs
- Timer.cs
- RangeContentEnumerator.cs
- SelectorAutomationPeer.cs
- PolyBezierSegment.cs
- SourceElementsCollection.cs
- Size3D.cs
- METAHEADER.cs
- DefaultConfirmation.cs
- DomainConstraint.cs
- AccessDataSourceView.cs
- Figure.cs
- _BufferOffsetSize.cs
- FileAuthorizationModule.cs
- FixedSOMTextRun.cs
- DynamicHyperLink.cs
- DoubleAnimationBase.cs
- MessagingDescriptionAttribute.cs
- HtmlWindowCollection.cs
- ListSortDescription.cs
- ObjectDisposedException.cs