Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / wpf / src / Base / MS / Internal / Security / RightsManagement / SafeRightsManagementQueryHandle.cs / 1 / SafeRightsManagementQueryHandle.cs
//------------------------------------------------------------------------------ // //// Copyright (c) Microsoft Corporation. All rights reserved. // // // Description: // SafeRightsManagementQueryHandle class // // History: // 10/12/2005: SarjanaS: Initial implementation. // //----------------------------------------------------------------------------- using System; using System.Runtime.InteropServices; using Microsoft.Win32.SafeHandles; using System.Security; namespace MS.Internal.Security.RightsManagement { [SecurityCritical(SecurityCriticalScope.Everything)] internal sealed class SafeRightsManagementQueryHandle : SafeHandle { //Although it is not obvious this constructor is being called by the interop services // it throws exceptions without it private SafeRightsManagementQueryHandle() : base(IntPtr.Zero, true) { } // We have incompatibility between SafeHandle class hierarchy and the unmanaged // DRM SDK declarations. In the safe handle hierarchy it is assumed that the type // of handle is the IntPtr (64 or 32 bit depending on the platform). In the unmanaged // SDK C++ unsigned long type is used, which is 32 bit regardless of the platform. // We have decided the safest thing would be to still use the SafeHandle classes // and subclasses and cast variable back and force under assumption that IntPtr // is at least as big as unsigned long (in the managed code we generally use uint // declaration for that) internal SafeRightsManagementQueryHandle(uint handle) : base((IntPtr)handle, true) // "true" means "owns the handle" { } // base class expects us to override this method with the handle specific release code protected override bool ReleaseHandle() { int z = 0; if (!IsInvalid) { // we can not use safe handle in the DrmClose... function // as the SafeHandle implementation marks this instance as an invalid by the time // ReleaseHandle is called. After that marshalling code doesn't let the current instance // of the Safe*Handle sub-class to cross managed/unmanaged boundary. z = SafeNativeMethods.DRMCloseQueryHandle((uint)this.handle); #if DEBUG Errors.ThrowOnErrorCode(z); #endif // This member might be called twice(depending on the client app). In order to // prevent Unmanaged RM SDK from returning an error (Handle is already closed) // we need to mark our handle as invalid after successful close call base.SetHandle(IntPtr.Zero); } return (z>=0); } // apparently there is no existing implementation that treats Zero and only Zero as an invalid value // so we are sub-classing the base class and we need to override the IsInvalid property along with // ReleaseHandle implementation public override bool IsInvalid { get { return this.handle.Equals(IntPtr.Zero); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ // //// Copyright (c) Microsoft Corporation. All rights reserved. // // // Description: // SafeRightsManagementQueryHandle class // // History: // 10/12/2005: SarjanaS: Initial implementation. // //----------------------------------------------------------------------------- using System; using System.Runtime.InteropServices; using Microsoft.Win32.SafeHandles; using System.Security; namespace MS.Internal.Security.RightsManagement { [SecurityCritical(SecurityCriticalScope.Everything)] internal sealed class SafeRightsManagementQueryHandle : SafeHandle { //Although it is not obvious this constructor is being called by the interop services // it throws exceptions without it private SafeRightsManagementQueryHandle() : base(IntPtr.Zero, true) { } // We have incompatibility between SafeHandle class hierarchy and the unmanaged // DRM SDK declarations. In the safe handle hierarchy it is assumed that the type // of handle is the IntPtr (64 or 32 bit depending on the platform). In the unmanaged // SDK C++ unsigned long type is used, which is 32 bit regardless of the platform. // We have decided the safest thing would be to still use the SafeHandle classes // and subclasses and cast variable back and force under assumption that IntPtr // is at least as big as unsigned long (in the managed code we generally use uint // declaration for that) internal SafeRightsManagementQueryHandle(uint handle) : base((IntPtr)handle, true) // "true" means "owns the handle" { } // base class expects us to override this method with the handle specific release code protected override bool ReleaseHandle() { int z = 0; if (!IsInvalid) { // we can not use safe handle in the DrmClose... function // as the SafeHandle implementation marks this instance as an invalid by the time // ReleaseHandle is called. After that marshalling code doesn't let the current instance // of the Safe*Handle sub-class to cross managed/unmanaged boundary. z = SafeNativeMethods.DRMCloseQueryHandle((uint)this.handle); #if DEBUG Errors.ThrowOnErrorCode(z); #endif // This member might be called twice(depending on the client app). In order to // prevent Unmanaged RM SDK from returning an error (Handle is already closed) // we need to mark our handle as invalid after successful close call base.SetHandle(IntPtr.Zero); } return (z>=0); } // apparently there is no existing implementation that treats Zero and only Zero as an invalid value // so we are sub-classing the base class and we need to override the IsInvalid property along with // ReleaseHandle implementation public override bool IsInvalid { get { return this.handle.Equals(IntPtr.Zero); } } } } // 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
- DbInsertCommandTree.cs
- CroppedBitmap.cs
- XmlQueryStaticData.cs
- GestureRecognitionResult.cs
- GraphicsContainer.cs
- PlainXmlDeserializer.cs
- EventEntry.cs
- SplineKeyFrames.cs
- LinkedResourceCollection.cs
- XmlSubtreeReader.cs
- IdentityReference.cs
- PeerNearMe.cs
- Mouse.cs
- ColorAnimationUsingKeyFrames.cs
- QueueProcessor.cs
- ControlCodeDomSerializer.cs
- Hashtable.cs
- Int32KeyFrameCollection.cs
- BinaryObjectInfo.cs
- ExtensionWindowHeader.cs
- EntityDataReader.cs
- Vector3DCollection.cs
- FixedMaxHeap.cs
- DockPanel.cs
- CompensationHandlingFilter.cs
- Int32CollectionValueSerializer.cs
- TreeView.cs
- AliasedSlot.cs
- HtmlShimManager.cs
- XmlNodeChangedEventArgs.cs
- TraceEventCache.cs
- ReadOnlyCollectionBase.cs
- ConstantSlot.cs
- SchemaMapping.cs
- TraceContext.cs
- DataServices.cs
- RunInstallerAttribute.cs
- SqlAggregateChecker.cs
- HttpHeaderCollection.cs
- CaseCqlBlock.cs
- WindowsStreamSecurityElement.cs
- ScalarRestriction.cs
- OutputCacheProfileCollection.cs
- Transform3D.cs
- XmlComment.cs
- DataGridItemCollection.cs
- PriorityItem.cs
- PropertyValueUIItem.cs
- DoubleAnimationUsingKeyFrames.cs
- StorageSetMapping.cs
- FormsIdentity.cs
- BrowserCapabilitiesFactory.cs
- SimplePropertyEntry.cs
- NodeInfo.cs
- FreezableDefaultValueFactory.cs
- DataListCommandEventArgs.cs
- RadioButton.cs
- StringCollection.cs
- Adorner.cs
- OutputCacheSettingsSection.cs
- PerformanceCounterManager.cs
- FlowDocumentPage.cs
- Help.cs
- CacheSection.cs
- GridViewItemAutomationPeer.cs
- Decoder.cs
- ResourceExpression.cs
- Latin1Encoding.cs
- LayoutTable.cs
- ProcessManager.cs
- Int32Rect.cs
- Utilities.cs
- ChildDocumentBlock.cs
- DashStyle.cs
- ComPlusServiceHost.cs
- Matrix3DValueSerializer.cs
- EventItfInfo.cs
- BindingNavigator.cs
- WebPartDisplayModeCollection.cs
- PathHelper.cs
- BindingElement.cs
- UpDownBase.cs
- VirtualizingPanel.cs
- ListenerConnectionModeReader.cs
- ExeConfigurationFileMap.cs
- ComplexType.cs
- ModelPerspective.cs
- PointAnimationBase.cs
- PeerNameRegistration.cs
- TokenizerHelper.cs
- Menu.cs
- PropertyNames.cs
- InputScope.cs
- WebHttpSecurity.cs
- MessageBox.cs
- InteropBitmapSource.cs
- NativeMethods.cs
- CompoundFileStorageReference.cs
- NavigationExpr.cs
- TdsEnums.cs