aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuke <luke.pulverenti@gmail.com>2015-03-03 21:13:59 -0500
committerLuke <luke.pulverenti@gmail.com>2015-03-03 21:13:59 -0500
commit7958d8b3803ec3455d016ad0d8e30bef5690888c (patch)
tree958c11358fa4a39e81626164106e8c67908c4a6d
parent5878190cab93a2e81418d296af69a3ec185f11bf (diff)
parent09d53e3c95d35d04f6907941ef7f7206e219ff1c (diff)
Merge pull request #1033 from jluce50/dev
Close thread handle after suspend/resume
-rw-r--r--MediaBrowser.ServerApplication/Native/WindowsProcessManager.cs15
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)