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
- BamlVersionHeader.cs
- GridItemPatternIdentifiers.cs
- ToolStripDropDownClosingEventArgs.cs
- RefType.cs
- TypeConverterValueSerializer.cs
- MessageQueueKey.cs
- PersonalizationProviderCollection.cs
- UITypeEditors.cs
- ProfileInfo.cs
- CheckedPointers.cs
- BoolExpression.cs
- UserControlBuildProvider.cs
- PrePostDescendentsWalker.cs
- GridViewSelectEventArgs.cs
- Int32Storage.cs
- RefreshResponseInfo.cs
- TiffBitmapDecoder.cs
- SqlXml.cs
- ToolStripPanelRow.cs
- IndexedEnumerable.cs
- DeferredElementTreeState.cs
- AppLevelCompilationSectionCache.cs
- Point3DAnimationBase.cs
- WinInet.cs
- DoubleAnimationClockResource.cs
- ClientUrlResolverWrapper.cs
- IChannel.cs
- SmiContext.cs
- xdrvalidator.cs
- SerializerProvider.cs
- StreamWriter.cs
- ReflectionTypeLoadException.cs
- Pointer.cs
- DataGridViewCellMouseEventArgs.cs
- sqlmetadatafactory.cs
- _TransmitFileOverlappedAsyncResult.cs
- FontDialog.cs
- ColorConverter.cs
- XsltContext.cs
- AsymmetricSignatureFormatter.cs
- Clock.cs
- SafeNativeMethods.cs
- SelectionItemPattern.cs
- BuilderElements.cs
- BamlCollectionHolder.cs
- UrlPath.cs
- SafeRegistryKey.cs
- PenContext.cs
- X509Extension.cs
- UMPAttributes.cs
- SafeNativeMethods.cs
- CfgParser.cs
- MimeFormReflector.cs
- RegistrySecurity.cs
- XmlExpressionDumper.cs
- precedingquery.cs
- ProtocolsSection.cs
- EventHandlersDesigner.cs
- ArraySet.cs
- TextRangeEditTables.cs
- SafeMILHandle.cs
- XmlSchemaSequence.cs
- XsltOutput.cs
- ColorContextHelper.cs
- HttpListenerRequest.cs
- XPathDocumentNavigator.cs
- TreeBuilder.cs
- StatusBarAutomationPeer.cs
- PolygonHotSpot.cs
- BamlRecordReader.cs
- SerialPort.cs
- DataGridSortingEventArgs.cs
- SerializationSectionGroup.cs
- Viewport2DVisual3D.cs
- AsmxEndpointPickerExtension.cs
- ListBox.cs
- Section.cs
- ConfigXmlDocument.cs
- HiddenField.cs
- Variant.cs
- AuthenticationModuleElementCollection.cs
- HandleValueEditor.cs
- SqlTypesSchemaImporter.cs
- DependentList.cs
- JavaScriptObjectDeserializer.cs
- PathFigureCollectionConverter.cs
- SecurityPermission.cs
- SoapClientMessage.cs
- SkipStoryboardToFill.cs
- TextEditorMouse.cs
- CompiledIdentityConstraint.cs
- WorkflowServiceHost.cs
- FixedNode.cs
- BooleanFunctions.cs
- ToggleProviderWrapper.cs
- WaitHandle.cs
- DelegateSerializationHolder.cs
- AnonymousIdentificationSection.cs
- _Rfc2616CacheValidators.cs
- WebPartDisplayModeEventArgs.cs