Skip to content

Commit

Permalink
Improved documentation and layout of the Snocket module
Browse files Browse the repository at this point in the history
  • Loading branch information
coot committed Jan 31, 2020
1 parent 934ad69 commit 69d6206
Showing 1 changed file with 45 additions and 9 deletions.
54 changes: 45 additions & 9 deletions ouroboros-network/src/Ouroboros/Network/Snocket.hs
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,17 @@
{-# LANGUAGE ScopedTypeVariables #-}

module Ouroboros.Network.Snocket
( Accept (..)
( -- * Snocket Interface
Accept (..)
, AddressFamily (..)
, Snocket (..)
-- ** Socket based Snocktes
, SocketSnocket
, socketSnocket
, rawSocketSnocket
-- ** Client Snockets
-- Using unix sockets (posix) or named pipes (windows)
--
, ClientSnocket
, clientSnocket
, ClientAddress
Expand Down Expand Up @@ -66,7 +71,7 @@ import Ouroboros.Network.IOManager
-- > loop s
--
-- To make common API for both we use a recursive type 'Accept', see
-- 'berkeleyAccept' below. Creation of the socket / named pipe is part of
-- 'berkeleyAccept' below. Creation of a socket / named pipe is part of
-- 'Snocket', but this means we need to have different recursion step for named
-- pipe & sockets. For sockets its recursion step will always return 'accept'
-- syscall; for named pipes the first callback will reuse the file descriptor
Expand All @@ -77,14 +82,9 @@ newtype Accept addr fd = Accept
{ runAccept :: IO (fd, addr, Accept addr fd)
}

data AddressFamily addr where

SocketFamily :: !Socket.Family
-> AddressFamily Socket.SockAddr

NamedPipeFamily :: AddressFamily FilePath


-- | BSD accept loop.
--
berkeleyAccept :: AssociateWithIOCP
-> Socket
-> Accept SockAddr Socket
Expand All @@ -107,6 +107,24 @@ berkeleyAccept iocp sock = go
return (sock', addr', go)


-- | We support either sockets or named pipes.
--
data AddressFamily addr where

SocketFamily :: !Socket.Family
-> AddressFamily Socket.SockAddr

NamedPipeFamily :: AddressFamily FilePath

instance Eq (AddressFamily addr) where
SocketFamily fam0 == SocketFamily fam1 = fam0 == fam1
NamedPipeFamily == NamedPipeFamily = True

instance Show (AddressFamily addr) where
show (SocketFamily fam) = show fam
show NamedPipeFamily = "NamedPipeFamily"


-- | Abstract communication interface that can be used by more than
-- 'Socket'. Snockets are polymorphic over monad which is used, this feature
-- is useful for testing and/or simulations.
Expand Down Expand Up @@ -145,15 +163,22 @@ data Snocket m fd addr = Snocket {
}


--
-- Socket based Snockets
--


socketAddrFamily
:: Socket.SockAddr
-> AddressFamily Socket.SockAddr
socketAddrFamily (Socket.SockAddrInet _ _ ) = SocketFamily Socket.AF_INET
socketAddrFamily (Socket.SockAddrInet6 _ _ _ _) = SocketFamily Socket.AF_INET6
socketAddrFamily (Socket.SockAddrUnix _ ) = SocketFamily Socket.AF_UNIX


type SocketSnocket = Snocket IO Socket SockAddr


-- | Create a 'Snocket' for the given 'Socket.Family'. In the 'bind' method set
-- 'Socket.ReuseAddr` and 'Socket.ReusePort'.
--
Expand Down Expand Up @@ -258,6 +283,11 @@ rawSocketSnocket iocp = Snocket {
return sd


--
-- NamedPipes based Snocket
--


#if defined(mingw32_HOST_OS)
type HANDLESnocket = Snocket IO Win32.HANDLE FilePath

Expand Down Expand Up @@ -342,6 +372,12 @@ namedPipeSnocket iocp name = Snocket {
return (hpipe, name, acceptNext)
#endif


--
-- Windows/POSIX type aliases
--


-- | System dependent ClientSnocket type
#if defined(mingw32_HOST_OS)
type ClientSnocket = HANDLESnocket
Expand Down

0 comments on commit 69d6206

Please sign in to comment.