SafeProcessHandle.cs source code in C# .NET

Source code for the .NET framework in C#

                        

Code:

/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / CompMod / Microsoft / Win32 / SafeHandles / SafeProcessHandle.cs / 1 / SafeProcessHandle.cs

                            // ==++== 
//
//   Copyright (c) Microsoft Corporation.  All rights reserved.
//
// ==--== 
/*============================================================
** 
** Class:  SafeProcessHandle 
**
** A wrapper for a process handle 
**
**
===========================================================*/
 
using System;
using System.Security; 
using System.Diagnostics; 
using System.Security.Permissions;
using System.Runtime.InteropServices; 
using System.Runtime.CompilerServices;
using Microsoft.Win32;
using Microsoft.Win32.SafeHandles;
using System.Runtime.ConstrainedExecution; 

namespace Microsoft.Win32.SafeHandles { 
    [HostProtectionAttribute(MayLeakOnAbort = true)] 
    [SuppressUnmanagedCodeSecurityAttribute]
    internal sealed class SafeProcessHandle : SafeHandleZeroOrMinusOneIsInvalid 
    {
        internal static SafeProcessHandle InvalidHandle = new SafeProcessHandle(IntPtr.Zero);

        // Note that OpenProcess returns 0 on failure 

        internal SafeProcessHandle() : base(true) {} 
 
        [SecurityPermission(SecurityAction.LinkDemand, UnmanagedCode=true)]
        internal SafeProcessHandle(IntPtr handle) : base (true) { 
            SetHandle(handle);
        }

        // Not currently called 
        //[SecurityPermission(SecurityAction.LinkDemand, UnmanagedCode=true)]
        //internal SafeProcessHandle(IntPtr existingHandle, bool ownsHandle) : base(ownsHandle) { 
        //    SetHandle(existingHandle); 
        //}
 
        [DllImport(ExternDll.Kernel32, CharSet=System.Runtime.InteropServices.CharSet.Auto, SetLastError=true)]
        internal static extern SafeProcessHandle OpenProcess(int access, bool inherit, int processId);

 
        internal void InitialSetHandle(IntPtr h){
            Debug.Assert(base.IsInvalid, "Safe handle should only be set once"); 
            base.handle = h; 
        }
 
        override protected bool ReleaseHandle()
        {
            return SafeNativeMethods.CloseHandle(handle);
        } 

    } 
} 

 



// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// ==++== 
//
//   Copyright (c) Microsoft Corporation.  All rights reserved.
//
// ==--== 
/*============================================================
** 
** Class:  SafeProcessHandle 
**
** A wrapper for a process handle 
**
**
===========================================================*/
 
using System;
using System.Security; 
using System.Diagnostics; 
using System.Security.Permissions;
using System.Runtime.InteropServices; 
using System.Runtime.CompilerServices;
using Microsoft.Win32;
using Microsoft.Win32.SafeHandles;
using System.Runtime.ConstrainedExecution; 

namespace Microsoft.Win32.SafeHandles { 
    [HostProtectionAttribute(MayLeakOnAbort = true)] 
    [SuppressUnmanagedCodeSecurityAttribute]
    internal sealed class SafeProcessHandle : SafeHandleZeroOrMinusOneIsInvalid 
    {
        internal static SafeProcessHandle InvalidHandle = new SafeProcessHandle(IntPtr.Zero);

        // Note that OpenProcess returns 0 on failure 

        internal SafeProcessHandle() : base(true) {} 
 
        [SecurityPermission(SecurityAction.LinkDemand, UnmanagedCode=true)]
        internal SafeProcessHandle(IntPtr handle) : base (true) { 
            SetHandle(handle);
        }

        // Not currently called 
        //[SecurityPermission(SecurityAction.LinkDemand, UnmanagedCode=true)]
        //internal SafeProcessHandle(IntPtr existingHandle, bool ownsHandle) : base(ownsHandle) { 
        //    SetHandle(existingHandle); 
        //}
 
        [DllImport(ExternDll.Kernel32, CharSet=System.Runtime.InteropServices.CharSet.Auto, SetLastError=true)]
        internal static extern SafeProcessHandle OpenProcess(int access, bool inherit, int processId);

 
        internal void InitialSetHandle(IntPtr h){
            Debug.Assert(base.IsInvalid, "Safe handle should only be set once"); 
            base.handle = h; 
        }
 
        override protected bool ReleaseHandle()
        {
            return SafeNativeMethods.CloseHandle(handle);
        } 

    } 
} 

 



// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
                        

Link Menu

Network programming in C#, Network Programming in VB.NET, Network Programming in .NET
This book is available now!
Buy at Amazon US or
Buy at Amazon UK