Copyright | (c) 2014-2015, Peter Trško |
---|---|
License | BSD3 |
Maintainer | peter.trsko@gmail.com |
Stability | unstable (internal module) |
Portability | CPP, FlexibleContexts, NoImplicitPrelude |
Safe Haskell | None |
Language | Haskell2010 |
Module defines helper functions that would be ideally provided by streaming-commons package and some wrappers with specialised type signatures.
Internal packages are here to provide access to internal definitions for library writers, but they should not be used in application code.
Preferably use qualified import, e.g.:
import qualified Data.ConnectionPool.Internal.Streaming as Internal
This module doesn't neither depend on resource-pool package nor any other module of this package, with notable exception of Data.ConnectionPool.Internal.HandlerParams, and it shoud stay that way. This module uses CPP to get OS specific things right. Most importantly Windows doesn't support UNIX Sockets.
Please, bear above in mind when doing modifications.
- acquireTcpClientConnection :: ClientSettings -> IO (Socket, SockAddr)
- runTcpApp :: MonadBaseControl IO m => Maybe SockAddr -> (AppData -> m r) -> HandlerParams -> Socket -> SockAddr -> m r
- runTcpAppImpl :: MonadBaseControl IO m => Maybe SockAddr -> Socket -> SockAddr -> Int -> (AppData -> m r) -> m r
- fromClientSettings :: ClientSettings -> HandlerParams
- runUnixApp :: MonadBaseControl IO m => (AppDataUnix -> m r) -> HandlerParams -> Socket -> () -> m r
- runUnixAppImpl :: MonadBaseControl IO m => Socket -> Int -> (AppDataUnix -> m r) -> m r
- fromClientSettingsUnix :: ClientSettingsUnix -> HandlerParams
TCP
acquireTcpClientConnection :: ClientSettings -> IO (Socket, SockAddr) Source
Wrapper for getSocketFamilyTCP
that takes ClientSettings
instead of
individual parameters.
:: MonadBaseControl IO m | |
=> Maybe SockAddr | |
-> (AppData -> m r) | |
-> HandlerParams | Parameters passed down to connection handler |
-> Socket | |
-> SockAddr | |
-> m r |
Wrapper for runTcpAppImpl
with a type signature that is more natural
for implementing a TCP specific
withConnection
.
Definition changed in version 0.1.3.
:: MonadBaseControl IO m | |
=> Maybe SockAddr | |
-> Socket | |
-> SockAddr | |
-> Int | Buffer size used while reading from socket. Since version 0.1.3. |
-> (AppData -> m r) | |
-> m r |
Simplified runTCPClient
and
runTCPServer
that provides only construction of
AppData
and passing it to a callback function.
Definition changed in version 0.1.3.
fromClientSettings :: ClientSettings -> HandlerParams Source
Construct HandlerParams
that are passed to individual TCP connection
handlers.
Since version 0.1.3.
Unix Socket
:: MonadBaseControl IO m | |
=> (AppDataUnix -> m r) | |
-> HandlerParams | Parameters passed down to connection handler |
-> Socket | |
-> () | |
-> m r |
Wrapper for runUnixAppImpl
with a type signature that is more natural
for implementing a UNIX Socket specific
withConnection
.
Definition changed in version 0.1.3.
:: MonadBaseControl IO m | |
=> Socket | |
-> Int | Buffer size used while reading from socket. Since version 0.1.3. |
-> (AppDataUnix -> m r) | |
-> m r |
Simplified runUnixClient
and
runUnixServer
that provides only construction of
AppDataUnix
and passing it to a callback function.
Definition changed in version 0.1.3.
fromClientSettingsUnix :: ClientSettingsUnix -> HandlerParams Source
Construct HandlerParams
that are passed to individual UNIX socket
connection handlers.
Since version 0.1.3.