mirror of
https://github.com/snoyberg/keter.git
synced 2024-12-16 10:02:24 +03:00
37 lines
1.1 KiB
Haskell
37 lines
1.1 KiB
Haskell
|
{-# LANGUAGE ForeignFunctionInterface #-}
|
||
|
-- | Ensures that processes are stopped when Keter shuts down.
|
||
|
module Keter.ProcessTracker
|
||
|
( ProcessTracker
|
||
|
, trackProcess
|
||
|
, initProcessTracker
|
||
|
) where
|
||
|
|
||
|
import System.Process.Internals
|
||
|
import Foreign.C (CInt (..))
|
||
|
import System.Posix.Types (CPid (..))
|
||
|
import Control.Concurrent.MVar (readMVar)
|
||
|
|
||
|
foreign import ccall unsafe "launch_process_tracker"
|
||
|
c_launch_process_tracker :: IO CInt
|
||
|
|
||
|
foreign import ccall unsafe "track_process"
|
||
|
c_track_process :: ProcessTracker -> CPid -> CInt -> IO ()
|
||
|
|
||
|
newtype ProcessTracker = ProcessTracker CInt
|
||
|
|
||
|
initProcessTracker :: IO ProcessTracker
|
||
|
initProcessTracker = do
|
||
|
i <- c_launch_process_tracker
|
||
|
if i == -1
|
||
|
then error "Unable to launch process tracker"
|
||
|
else return $ ProcessTracker i
|
||
|
|
||
|
trackProcess :: ProcessTracker -> ProcessHandle -> IO (IO ())
|
||
|
trackProcess pt (ProcessHandle mph) = do
|
||
|
mpid <- readMVar mph
|
||
|
case mpid of
|
||
|
ClosedHandle{} -> return $ return ()
|
||
|
OpenHandle pid -> do
|
||
|
c_track_process pt pid 1
|
||
|
return $ c_track_process pt pid 0
|