Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / wpf / src / Core / CSharp / System / Windows / Media / SafeMILHandle.cs / 1 / 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
- SqlRowUpdatingEvent.cs
- IdentityHolder.cs
- SyndicationElementExtensionCollection.cs
- BuiltInExpr.cs
- WorkflowViewStateService.cs
- XmlSchemaIdentityConstraint.cs
- ErrorWebPart.cs
- EventLogger.cs
- SignatureHelper.cs
- WebResponse.cs
- ServiceReference.cs
- ObjectDataSourceView.cs
- DataRelationPropertyDescriptor.cs
- UrlSyndicationContent.cs
- TextOptions.cs
- Content.cs
- CodeTypeReference.cs
- CurrencyManager.cs
- DataGridViewLayoutData.cs
- SimpleExpression.cs
- ReadOnlyDataSource.cs
- CodeSnippetTypeMember.cs
- DataServiceRequestOfT.cs
- PropertyNames.cs
- NullableConverter.cs
- SyndicationDeserializer.cs
- ObjectStateFormatter.cs
- DesignerProperties.cs
- Invariant.cs
- SelectionProcessor.cs
- ReadOnlyPermissionSet.cs
- XmlSchemaProviderAttribute.cs
- ListCollectionView.cs
- DiffuseMaterial.cs
- XmlSignatureProperties.cs
- ErrorTableItemStyle.cs
- EventDescriptor.cs
- TextEditorLists.cs
- HttpCachePolicyElement.cs
- ExpressionVisitor.cs
- Camera.cs
- OleDbSchemaGuid.cs
- RuleValidation.cs
- ItemCheckedEvent.cs
- ClientScriptManager.cs
- Error.cs
- DataServiceException.cs
- BooleanAnimationUsingKeyFrames.cs
- DocumentViewerConstants.cs
- PreviousTrackingServiceAttribute.cs
- ClientEventManager.cs
- DrawListViewColumnHeaderEventArgs.cs
- StandardOleMarshalObject.cs
- DSASignatureDeformatter.cs
- ButtonBase.cs
- TriggerActionCollection.cs
- FunctionParameter.cs
- ObjectItemNoOpAssemblyLoader.cs
- ArithmeticException.cs
- ClientConfigPaths.cs
- ReaderWriterLock.cs
- XMLDiffLoader.cs
- ParameterCollection.cs
- SecurityPermission.cs
- EventRouteFactory.cs
- PathFigureCollection.cs
- HttpCapabilitiesBase.cs
- EmbeddedMailObjectsCollection.cs
- DesignerAdapterAttribute.cs
- PageAdapter.cs
- NativeMethods.cs
- WebPartChrome.cs
- GridView.cs
- TextRange.cs
- SchemaImporter.cs
- FlowDocumentPageViewerAutomationPeer.cs
- Registry.cs
- Boolean.cs
- StaticDataManager.cs
- Rijndael.cs
- PromptBuilder.cs
- SafeNativeMethods.cs
- VBCodeProvider.cs
- DataRecordInfo.cs
- WebPartConnectionsCancelEventArgs.cs
- TerminatorSinks.cs
- ScopedMessagePartSpecification.cs
- WebPart.cs
- ComplexPropertyEntry.cs
- NTAccount.cs
- Brush.cs
- DbgCompiler.cs
- XmlAttribute.cs
- WindowsFormsLinkLabel.cs
- WinEventTracker.cs
- ObjectDataSourceStatusEventArgs.cs
- XmlAtomicValue.cs
- path.cs
- SingleKeyFrameCollection.cs
- DelegateArgumentValue.cs