Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / wpf / src / Core / CSharp / System / Windows / Media / SafeMILHandle.cs / 2 / SafeMILHandle.cs
//---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // // Description: // A safe way to deal with unmanaged MIL interface pointers. //--------------------------------------------------------------------------- using System; using System.IO; using System.Security; using System.Security.Permissions; using System.Collections; using System.Reflection; using MS.Internal; using MS.Win32; using System.Diagnostics; using System.Windows.Media; using System.Runtime; using System.Runtime.InteropServices; using System.Runtime.CompilerServices; using Microsoft.Win32.SafeHandles; using Microsoft.Internal; using UnsafeNativeMethods=MS.Win32.PresentationCore.UnsafeNativeMethods; namespace System.Windows.Media { internal class SafeMILHandle : SafeHandleZeroOrMinusOneIsInvalid { ////// Use this constructor if the handle isn't ready yet and later /// set the handle with SetHandle. SafeMILHandle owns the release /// of the handle. /// ////// Critical: This derives from a class that has a link demand and inheritance demand /// TreatAsSafe: Ok to call constructor /// [SecurityCritical,SecurityTreatAsSafe] internal SafeMILHandle() : base(true) { } ////// Use this constructor if the handle exists at construction time. /// SafeMILHandle owns the release of the parameter. /// ////// Critical: This code calls UpdateEstimatedSize. /// It is used to keep memory around /// [SecurityCritical] internal SafeMILHandle(IntPtr handle, long estimatedSize) : base(true) { SetHandle(handle); // // Hint the GC at the size of the unmanaged memory associated with // this object. We release pressure in the finalizer. // UpdateEstimatedSize(estimatedSize); } ////// Change our size to the new size specified /// ////// Critical: This code calls into AddMemoryPressure and RemoveMemoryPressure /// both of which have link demands. It is used to keep memory around /// [SecurityCritical] internal void UpdateEstimatedSize(long estimatedSize) { if (_gcPressure > 0) { MemoryPressure.Remove(_gcPressure); } _gcPressure = estimatedSize; if (_gcPressure > 0) { MemoryPressure.Add(_gcPressure); } } ////// Critical - calls unmanaged code, not treat as safe because you must /// validate that handle is a valid COM object. /// [SecurityCritical] protected override bool ReleaseHandle() { UnsafeNativeMethods.MILUnknown.ReleaseInterface(ref handle); // // We've released the unmangaed memory, so remove associated // GC pressure. // UpdateEstimatedSize(0); return true; } // // Estimated size in bytes of the unmanaged memory we are holding onto // private long _gcPressure; } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // // Description: // A safe way to deal with unmanaged MIL interface pointers. //--------------------------------------------------------------------------- using System; using System.IO; using System.Security; using System.Security.Permissions; using System.Collections; using System.Reflection; using MS.Internal; using MS.Win32; using System.Diagnostics; using System.Windows.Media; using System.Runtime; using System.Runtime.InteropServices; using System.Runtime.CompilerServices; using Microsoft.Win32.SafeHandles; using Microsoft.Internal; using UnsafeNativeMethods=MS.Win32.PresentationCore.UnsafeNativeMethods; namespace System.Windows.Media { internal class SafeMILHandle : SafeHandleZeroOrMinusOneIsInvalid { ////// Use this constructor if the handle isn't ready yet and later /// set the handle with SetHandle. SafeMILHandle owns the release /// of the handle. /// ////// Critical: This derives from a class that has a link demand and inheritance demand /// TreatAsSafe: Ok to call constructor /// [SecurityCritical,SecurityTreatAsSafe] internal SafeMILHandle() : base(true) { } ////// Use this constructor if the handle exists at construction time. /// SafeMILHandle owns the release of the parameter. /// ////// Critical: This code calls UpdateEstimatedSize. /// It is used to keep memory around /// [SecurityCritical] internal SafeMILHandle(IntPtr handle, long estimatedSize) : base(true) { SetHandle(handle); // // Hint the GC at the size of the unmanaged memory associated with // this object. We release pressure in the finalizer. // UpdateEstimatedSize(estimatedSize); } ////// Change our size to the new size specified /// ////// Critical: This code calls into AddMemoryPressure and RemoveMemoryPressure /// both of which have link demands. It is used to keep memory around /// [SecurityCritical] internal void UpdateEstimatedSize(long estimatedSize) { if (_gcPressure > 0) { MemoryPressure.Remove(_gcPressure); } _gcPressure = estimatedSize; if (_gcPressure > 0) { MemoryPressure.Add(_gcPressure); } } ////// Critical - calls unmanaged code, not treat as safe because you must /// validate that handle is a valid COM object. /// [SecurityCritical] protected override bool ReleaseHandle() { UnsafeNativeMethods.MILUnknown.ReleaseInterface(ref handle); // // We've released the unmangaed memory, so remove associated // GC pressure. // UpdateEstimatedSize(0); return true; } // // Estimated size in bytes of the unmanaged memory we are holding onto // private long _gcPressure; } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- XdrBuilder.cs
- PanelDesigner.cs
- NavigationEventArgs.cs
- AddValidationError.cs
- SafeFileMappingHandle.cs
- AttributeAction.cs
- XmlConverter.cs
- SqlReorderer.cs
- EncryptedKey.cs
- SingleAnimationBase.cs
- UnaryNode.cs
- EventListenerClientSide.cs
- ImportedNamespaceContextItem.cs
- IconHelper.cs
- DesignTableCollection.cs
- ThreadStateException.cs
- ParameterCollection.cs
- Compiler.cs
- TrackingConditionCollection.cs
- SqlFunctionAttribute.cs
- WindowsAuthenticationEventArgs.cs
- BmpBitmapEncoder.cs
- PeerService.cs
- ImpersonateTokenRef.cs
- DataGridViewLinkColumn.cs
- Control.cs
- BrowsableAttribute.cs
- TransactionManager.cs
- Pick.cs
- Wildcard.cs
- BreakRecordTable.cs
- Matrix3DValueSerializer.cs
- SelectionRangeConverter.cs
- RefExpr.cs
- validation.cs
- RegistrySecurity.cs
- SpecialFolderEnumConverter.cs
- ConstrainedDataObject.cs
- SafeLibraryHandle.cs
- JsonReader.cs
- DataTableReader.cs
- MobileUserControl.cs
- Decoder.cs
- BoolExpressionVisitors.cs
- TextBoxView.cs
- VectorKeyFrameCollection.cs
- CalendarDateRangeChangingEventArgs.cs
- DropDownList.cs
- ObjectQueryExecutionPlan.cs
- WindowClosedEventArgs.cs
- ContentOperations.cs
- ColumnWidthChangingEvent.cs
- FixedSOMTableRow.cs
- RadioButtonPopupAdapter.cs
- FixedNode.cs
- DecimalSumAggregationOperator.cs
- HandlerBase.cs
- HttpProcessUtility.cs
- AVElementHelper.cs
- ValueHandle.cs
- SymbolResolver.cs
- XmlNamedNodeMap.cs
- LayoutSettings.cs
- CodeCompiler.cs
- LayoutTable.cs
- DataGridViewColumnCollection.cs
- XmlChoiceIdentifierAttribute.cs
- ThreadInterruptedException.cs
- MouseGesture.cs
- TextServicesCompartmentEventSink.cs
- ColorDialog.cs
- SHA512.cs
- SafePEFileHandle.cs
- Semaphore.cs
- XmlWriter.cs
- InfoCardProofToken.cs
- UnsafeNativeMethods.cs
- VirtualizedItemPattern.cs
- Span.cs
- WebBrowser.cs
- BinaryFormatterSinks.cs
- SocketStream.cs
- TypeLoadException.cs
- CompositeFontInfo.cs
- ScrollBarRenderer.cs
- SHA1.cs
- WindowsRichEdit.cs
- ExceptionList.cs
- DocumentPage.cs
- AuthenticationModuleElementCollection.cs
- StylusPointCollection.cs
- NativeMethods.cs
- TdsParserStaticMethods.cs
- CompilationSection.cs
- InputLanguage.cs
- CodeIdentifier.cs
- ProgressBar.cs
- RSACryptoServiceProvider.cs
- dsa.cs
- CodeCommentStatementCollection.cs