Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / 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
- Win32.cs
- GridView.cs
- TreeNodeEventArgs.cs
- WebBrowserProgressChangedEventHandler.cs
- Script.cs
- ExceptionHelpers.cs
- SafeFileHandle.cs
- CreateSequence.cs
- CompilerResults.cs
- HtmlInputSubmit.cs
- HTTPNotFoundHandler.cs
- Int64Storage.cs
- Trace.cs
- DebugTracing.cs
- LinqDataSource.cs
- UdpUtility.cs
- DiffuseMaterial.cs
- ObjectStateFormatter.cs
- UInt32.cs
- CallSite.cs
- ListBindingHelper.cs
- TcpClientChannel.cs
- LayoutSettings.cs
- TextEditorMouse.cs
- XmlSchemaSimpleTypeList.cs
- assertwrapper.cs
- Viewport3DVisual.cs
- VariableAction.cs
- SourceItem.cs
- BitmapEffect.cs
- VisualStates.cs
- TemplatedAdorner.cs
- CredentialCache.cs
- WriteLineDesigner.xaml.cs
- versioninfo.cs
- TemplateBindingExpressionConverter.cs
- EventListenerClientSide.cs
- InternalDispatchObject.cs
- DeleteMemberBinder.cs
- ContentElement.cs
- LayoutEvent.cs
- StrokeCollection2.cs
- PEFileReader.cs
- RecognizedWordUnit.cs
- AmbientValueAttribute.cs
- ImageList.cs
- MultipleViewProviderWrapper.cs
- XmlBinaryWriter.cs
- EmptyQuery.cs
- RelationshipType.cs
- DeviceContext.cs
- WebPartManagerDesigner.cs
- Suspend.cs
- TextTreeInsertElementUndoUnit.cs
- ConversionValidationRule.cs
- TrustManager.cs
- Point3D.cs
- RoutedEventHandlerInfo.cs
- Wizard.cs
- CrossAppDomainChannel.cs
- Semaphore.cs
- TreeSet.cs
- PipelineModuleStepContainer.cs
- InstanceOwnerQueryResult.cs
- UrlAuthFailedErrorFormatter.cs
- LoginDesigner.cs
- smtppermission.cs
- CompletedAsyncResult.cs
- RequiredArgumentAttribute.cs
- _BaseOverlappedAsyncResult.cs
- regiisutil.cs
- Vector3DAnimation.cs
- CompilerInfo.cs
- InternalCache.cs
- WindowsGraphics.cs
- SafeNativeMethodsOther.cs
- Vector3DConverter.cs
- XmlTextReader.cs
- _CacheStreams.cs
- EntityTypeEmitter.cs
- PageContentAsyncResult.cs
- DataControlFieldHeaderCell.cs
- BindStream.cs
- MenuItem.cs
- SystemColorTracker.cs
- DataRecordInternal.cs
- EdgeModeValidation.cs
- DataStreamFromComStream.cs
- TargetInvocationException.cs
- JsonObjectDataContract.cs
- GridViewCommandEventArgs.cs
- PingReply.cs
- XmlWriterSettings.cs
- MasterPage.cs
- SchemaNames.cs
- Encoding.cs
- LoginCancelEventArgs.cs
- IdentityHolder.cs
- TaiwanLunisolarCalendar.cs
- ChangeConflicts.cs