module SocketActivation.GetFileDescriptors where
import Essentials
import Data.Either (Either)
import Data.List (take)
import Prelude (fromIntegral)
import System.IO (IO)
import SocketActivation.Concepts (Fd (..), Error, Count (countNat))
import SocketActivation.Env (getEnv')
import SocketActivation.IO (IO' (IO', run))
getFileDescriptorList :: IO (Either Error [Fd])
getFileDescriptorList :: IO (Either Error [Fd])
getFileDescriptorList = forall a. IO' a -> IO (Either Error a)
run forall a b. (a -> b) -> a -> b
$ forall a. IO (Either Error a) -> IO' a
IO' (forall a. Env' a => IO (Either Error a)
getEnv' @Count) forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&> Count -> [Fd]
fds
fds :: Count -> [Fd]
fds :: Count -> [Fd]
fds Count
n = forall a. Int -> [a] -> [a]
take (forall a b. (Integral a, Num b) => a -> b
fromIntegral (Count -> Natural
countNat Count
n)) [CInt -> Fd
Fd CInt
3 ..]