diff options
| author | Luke <luke.pulverenti@gmail.com> | 2015-03-03 21:13:59 -0500 |
|---|---|---|
| committer | Luke <luke.pulverenti@gmail.com> | 2015-03-03 21:13:59 -0500 |
| commit | 7958d8b3803ec3455d016ad0d8e30bef5690888c (patch) | |
| tree | 958c11358fa4a39e81626164106e8c67908c4a6d | |
| parent | 5878190cab93a2e81418d296af69a3ec185f11bf (diff) | |
| parent | 09d53e3c95d35d04f6907941ef7f7206e219ff1c (diff) | |
Merge pull request #1033 from jluce50/dev
Close thread handle after suspend/resume
| -rw-r--r-- | MediaBrowser.ServerApplication/Native/WindowsProcessManager.cs | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/MediaBrowser.ServerApplication/Native/WindowsProcessManager.cs b/MediaBrowser.ServerApplication/Native/WindowsProcessManager.cs index f3497aef5..a88f5c1e5 100644 --- a/MediaBrowser.ServerApplication/Native/WindowsProcessManager.cs +++ b/MediaBrowser.ServerApplication/Native/WindowsProcessManager.cs @@ -29,8 +29,11 @@ namespace MediaBrowser.ServerApplication.Native static extern IntPtr OpenThread(ThreadAccess dwDesiredAccess, bool bInheritHandle, uint dwThreadId); [DllImport("kernel32.dll")] static extern uint SuspendThread(IntPtr hThread); - [DllImport("kernel32.dll")] - static extern int ResumeThread(IntPtr hThread); + [DllImport("kernel32.dll")]
+ static extern int ResumeThread(IntPtr hThread);
+ [DllImport("kernel32.dll")]
+ [return: MarshalAs(UnmanagedType.Bool)]
+ public static extern bool CloseHandle(IntPtr hThread); public static void Suspend(this Process process) { @@ -41,7 +44,8 @@ namespace MediaBrowser.ServerApplication.Native { break; } - SuspendThread(pOpenThread); + SuspendThread(pOpenThread);
+ CloseHandle(pOpenThread); } } public static void Resume(this Process process) @@ -52,8 +56,9 @@ namespace MediaBrowser.ServerApplication.Native if (pOpenThread == IntPtr.Zero) { break; - } - ResumeThread(pOpenThread); + }
+ ResumeThread(pOpenThread);
+ CloseHandle(pOpenThread); } } public static void Print(this Process process) |
