Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / 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
- DataGridColumnCollection.cs
- Hash.cs
- GroupDescription.cs
- ElementProxy.cs
- XmlUrlResolver.cs
- ProxyWebPart.cs
- ColumnMapTranslator.cs
- ZipIOLocalFileDataDescriptor.cs
- EntityDataSource.cs
- ParenthesizePropertyNameAttribute.cs
- RecipientInfo.cs
- COM2ExtendedUITypeEditor.cs
- MatrixTransform3D.cs
- PointLight.cs
- SharedPersonalizationStateInfo.cs
- QilFunction.cs
- Vector3DValueSerializer.cs
- ConfigurationManagerHelper.cs
- PageSettings.cs
- DocumentViewerBase.cs
- __FastResourceComparer.cs
- ComplexType.cs
- ExpressionBuilder.cs
- BitmapFrameEncode.cs
- RMEnrollmentPage1.cs
- BatchParser.cs
- ControlSerializer.cs
- Timer.cs
- Stream.cs
- CredentialCache.cs
- documentsequencetextview.cs
- ReachDocumentReferenceCollectionSerializer.cs
- Baml2006KeyRecord.cs
- PageMediaType.cs
- ComponentChangedEvent.cs
- FixedSOMSemanticBox.cs
- SerialReceived.cs
- InternalDispatchObject.cs
- ListBindingConverter.cs
- LassoHelper.cs
- CustomErrorCollection.cs
- SmiTypedGetterSetter.cs
- ArrangedElementCollection.cs
- DataGridViewLinkCell.cs
- BitmapEffect.cs
- ComboBoxItem.cs
- SynchronizationLockException.cs
- XDRSchema.cs
- WizardPanelChangingEventArgs.cs
- OperandQuery.cs
- SettingsBase.cs
- ActivityXRefPropertyEditor.cs
- Vector3D.cs
- ProgressPage.cs
- ExpressionWriter.cs
- ValidationResults.cs
- AlternationConverter.cs
- FileDetails.cs
- Double.cs
- ItemPager.cs
- WorkflowInspectionServices.cs
- DataTableReaderListener.cs
- BooleanConverter.cs
- ServicesUtilities.cs
- CodeCommentStatementCollection.cs
- WebPartChrome.cs
- SmiRequestExecutor.cs
- EventListenerClientSide.cs
- SystemBrushes.cs
- FileVersionInfo.cs
- SystemResourceHost.cs
- SerializationException.cs
- PersonalizationProvider.cs
- ParameterCollection.cs
- CompilerErrorCollection.cs
- Brush.cs
- XpsFixedDocumentSequenceReaderWriter.cs
- XmlNode.cs
- DigestTraceRecordHelper.cs
- Models.cs
- TableSectionStyle.cs
- ExpressionVisitorHelpers.cs
- ArraySet.cs
- DbParameterHelper.cs
- SliderAutomationPeer.cs
- WebControl.cs
- SqlConnection.cs
- InputDevice.cs
- BuildProvider.cs
- Stackframe.cs
- ValidatedControlConverter.cs
- SoapSchemaImporter.cs
- WebPartPersonalization.cs
- Maps.cs
- DataSourceSelectArguments.cs
- ObjectDisposedException.cs
- HtmlAnchor.cs
- StorageTypeMapping.cs
- DispatchRuntime.cs
- PropertyTab.cs