{-# LINE 1 "Z/IO/Network/SocketAddr.hsc" #-}
module Z.IO.Network.SocketAddr
(
SocketAddr(..)
, ipv4, ipv6
, sockAddrFamily
, withSocketAddr
, withSocketAddrUnsafe
, sizeOfSocketAddr
, withSocketAddrStorage
, withSocketAddrStorageUnsafe
, sizeOfSocketAddrStorage
, IPv4(..)
, ipv4Any
, ipv4Broadcast
, ipv4None
, ipv4Loopback
, ipv4UnspecificGroup
, ipv4AllHostsGroup
, ipv4MaxLocalGroup
, ipv4AddrToTuple
, tupleToIPv4Addr
, IPv6(..)
, ipv6Any
, ipv6Loopback
, ipv6AddrToTuple
, tupleToIPv6Addr
, FlowInfo
, ScopeID
, PortNumber(..)
, portAny
, SocketFamily
, pattern AF_UNSPEC
, pattern AF_INET
, pattern AF_INET6
, SocketType
, pattern SOCK_DGRAM
, pattern SOCK_STREAM
, pattern SOCK_SEQPACKET
, pattern SOCK_RAW
, pattern SOCK_RDM
, pattern SOCK_ANY
, ProtocolNumber
, pattern IPPROTO_DEFAULT
, pattern IPPROTO_IP
, pattern IPPROTO_TCP
, pattern IPPROTO_UDP
, peekSocketAddr
, pokeSocketAddr
, peekSocketAddrMBA
, pokeSocketAddrMBA
, htons
, ntohs
, ntohl
, htonl
) where
import Data.Bits
import Foreign
import Foreign.C
import GHC.Generics
import Numeric (showHex)
import System.IO.Unsafe
import Z.Data.CBytes
import Z.Data.Text.ShowT (ShowT(..))
import qualified Z.Data.Text.ShowT as T
import Z.Data.JSON (EncodeJSON(..), ToValue(..), FromValue(..), (.:))
import qualified Z.Data.JSON as JSON
import qualified Z.Data.JSON.Builder as B
import qualified Z.Data.Vector as V
import qualified Z.Data.Vector.Extra as V
import Z.IO.Exception
import Z.Foreign
{-# LINE 98 "Z/IO/Network/SocketAddr.hsc" #-}
{-# LINE 100 "Z/IO/Network/SocketAddr.hsc" #-}
{-# LINE 108 "Z/IO/Network/SocketAddr.hsc" #-}
type CSaFamily = (Word16)
{-# LINE 109 "Z/IO/Network/SocketAddr.hsc" #-}
{-# LINE 110 "Z/IO/Network/SocketAddr.hsc" #-}
data SocketAddr
= SocketAddrIPv4
{-# UNPACK #-} !IPv4
{-# UNPACK #-} !PortNumber
| SocketAddrIPv6
{-# UNPACK #-} !IPv6
{-# UNPACK #-} !PortNumber
{-# UNPACK #-} !FlowInfo
{-# UNPACK #-} !ScopeID
deriving (Eq, Ord, Generic)
instance EncodeJSON SocketAddr where
encodeJSON (SocketAddrIPv4 addr port) = T.curly $ do
"addr" `B.kv` encodeJSON addr
T.char7 ','
"port" `B.kv` encodeJSON port
encodeJSON (SocketAddrIPv6 addr port flow scope) = T.curly $ do
"addr" `B.kv` encodeJSON addr
T.char7 ','
"port" `B.kv` encodeJSON port
T.char7 ','
"flow" `B.kv` encodeJSON flow
T.char7 ','
"scope" `B.kv` encodeJSON scope
instance ToValue SocketAddr where
toValue (SocketAddrIPv4 addr port) = JSON.Object . V.pack $
[ ("addr", toValue addr)
, ("number", toValue port)
]
toValue (SocketAddrIPv6 addr port flow scope) = JSON.Object . V.pack $
[ ("addr", toValue addr)
, ("number", toValue port)
, ("flow", toValue flow)
, ("scope", toValue scope)
]
instance FromValue SocketAddr where
fromValue = JSON.withFlatMapR "Z.IO.Network.SocketAddr" $ \ fm -> do
(addrV :: V.PrimVector Word) <- fm .: "addr"
case V.length addrV of
4 -> do port <- fm .: "port"
let a = fromIntegral $ addrV `V.unsafeIndex` 0
b = fromIntegral $ addrV `V.unsafeIndex` 1
c = fromIntegral $ addrV `V.unsafeIndex` 2
d = fromIntegral $ addrV `V.unsafeIndex` 3
!addr = tupleToIPv4Addr (a,b,c,d)
return (SocketAddrIPv4 addr port)
8 -> do port <- fm .: "port"
flow <- fm .: "flow"
scope <- fm .: "scope"
let a = fromIntegral $ addrV `V.unsafeIndex` 0
b = fromIntegral $ addrV `V.unsafeIndex` 1
c = fromIntegral $ addrV `V.unsafeIndex` 2
d = fromIntegral $ addrV `V.unsafeIndex` 3
e = fromIntegral $ addrV `V.unsafeIndex` 4
f = fromIntegral $ addrV `V.unsafeIndex` 5
g = fromIntegral $ addrV `V.unsafeIndex` 6
h = fromIntegral $ addrV `V.unsafeIndex` 7
!addr = tupleToIPv6Addr (a,b,c,d,e,f,g,h)
return (SocketAddrIPv6 addr port flow scope)
_ -> JSON.fail' "wrong address length"
instance Show SocketAddr where show = T.toString
instance ShowT SocketAddr where
toUTF8BuilderP _ (SocketAddrIPv4 addr port)
= T.toUTF8Builder addr >> T.char7 ':' >> T.toUTF8Builder port
toUTF8BuilderP _ (SocketAddrIPv6 addr port _ _) = do
T.square (T.toUTF8Builder addr)
T.char7 ':'
T.toUTF8Builder port
sockAddrFamily :: SocketAddr -> SocketFamily
sockAddrFamily (SocketAddrIPv4 _ _) = AF_INET
sockAddrFamily (SocketAddrIPv6 _ _ _ _) = AF_INET6
type FlowInfo = Word32
type ScopeID = Word32
ipv4:: HasCallStack => CBytes -> PortNumber -> SocketAddr
ipv4 str (PortNumber port) = unsafeDupablePerformIO . withSocketAddrStorageUnsafe $ \ p ->
withCBytesUnsafe str $ \ cstr -> throwUVIfMinus_ $ uv_ip4_addr cstr (fromIntegral port) p
ipv6:: HasCallStack => CBytes -> PortNumber -> SocketAddr
ipv6 str (PortNumber port) = unsafeDupablePerformIO . withSocketAddrStorageUnsafe $ \ p ->
withCBytesUnsafe str $ \ cstr -> throwUVIfMinus_ $ uv_ip6_addr cstr (fromIntegral port) p
newtype IPv4 = IPv4 { getIPv4Addr :: Word32 }
deriving (Eq, Ord, Generic)
instance EncodeJSON IPv4 where
{-# INLINE encodeJSON #-}
encodeJSON = encodeJSON . ipv4AddrToTuple
instance ToValue IPv4 where
{-# INLINE toValue #-}
toValue = toValue . ipv4AddrToTuple
instance FromValue IPv4 where
{-# INLINE fromValue #-}
fromValue v = tupleToIPv4Addr <$> fromValue v
instance Show IPv4 where show = T.toString
instance ShowT IPv4 where
toUTF8BuilderP _ ia = do
let (a,b,c,d) = ipv4AddrToTuple ia
T.int a
T.char7 '.'
T.int b
T.char7 '.'
T.int c
T.char7 '.'
T.int d
ipv4Any :: IPv4
ipv4Any = IPv4 0
ipv4Broadcast :: IPv4
ipv4Broadcast = tupleToIPv4Addr (255,255,255,255)
ipv4None :: IPv4
ipv4None = tupleToIPv4Addr (255,255,255,255)
ipv4Loopback :: IPv4
ipv4Loopback = tupleToIPv4Addr (127, 0, 0, 1)
ipv4UnspecificGroup :: IPv4
ipv4UnspecificGroup = tupleToIPv4Addr (224, 0, 0, 0)
ipv4AllHostsGroup :: IPv4
ipv4AllHostsGroup = tupleToIPv4Addr (224, 0, 0, 1)
ipv4MaxLocalGroup :: IPv4
ipv4MaxLocalGroup = tupleToIPv4Addr (224, 0, 0,255)
instance Storable IPv4 where
sizeOf _ = 4
alignment _ = alignment (undefined :: Word32)
peek p = (IPv4 . ntohl) `fmap` peekByteOff p 0
poke p (IPv4 ia) = pokeByteOff p 0 (htonl ia)
instance Unaligned IPv4 where
unalignedSize _ = 4
pokeMBA p off x = pokeMBA p off (htonl (getIPv4Addr x))
peekMBA p off = IPv4 . ntohl <$> peekMBA p off
indexBA p off = IPv4 (ntohl (indexBA p off))
ipv4AddrToTuple :: IPv4 -> (Word8, Word8, Word8, Word8)
ipv4AddrToTuple (IPv4 ia) =
let byte i = fromIntegral (ia `shiftR` i) :: Word8
in (byte 24, byte 16, byte 8, byte 0)
tupleToIPv4Addr :: (Word8, Word8, Word8, Word8) -> IPv4
tupleToIPv4Addr (b3, b2, b1, b0) =
let x `sl` i = fromIntegral x `shiftL` i :: Word32
in IPv4 $ (b3 `sl` 24) .|. (b2 `sl` 16) .|. (b1 `sl` 8) .|. (b0 `sl` 0)
data IPv6 = IPv6 {-# UNPACK #-}!Word32
{-# UNPACK #-}!Word32
{-# UNPACK #-}!Word32
{-# UNPACK #-}!Word32
deriving (Eq, Ord, Generic)
instance EncodeJSON IPv6 where
{-# INLINE encodeJSON #-}
encodeJSON addr = encodeJSON [a,b,c,d,e,f,g,h]
where (a,b,c,d,e,f,g,h) = ipv6AddrToTuple addr
instance ToValue IPv6 where
{-# INLINE toValue #-}
toValue addr = toValue [a,b,c,d,e,f,g,h]
where (a,b,c,d,e,f,g,h) = ipv6AddrToTuple addr
instance FromValue IPv6 where
{-# INLINE fromValue #-}
fromValue v = do
[a,b,c,d,e,f,g,h] <- fromValue v
return $! tupleToIPv6Addr (a,b,c,d,e,f,g,h)
instance Show IPv6 where show = T.toString
instance ShowT IPv6 where
toUTF8BuilderP _ ia6@(IPv6 a1 a2 a3 a4)
| a1 == 0 && a2 == 0 && a3 == 0xffff =
"::ffff:" >> T.toUTF8Builder (IPv4 a4)
| a1 == 0 && a2 == 0 && a3 == 0 && a4 >= 0x10000 =
"::" >> T.toUTF8Builder (IPv4 a4)
| end - begin > 1 =
showFields prefix >> "::" >> showFields suffix
| otherwise =
showFields fields
where
fields =
let (u7, u6, u5, u4, u3, u2, u1, u0) = ipv6AddrToTuple ia6 in
[u7, u6, u5, u4, u3, u2, u1, u0]
showFields = T.intercalateList (T.char7 ':') (\ f -> T.string7 (showHex f []))
!prefix = take begin fields
!suffix = drop end fields
begin = end + diff
(diff, end) = minimum $
scanl (\c i -> if i == 0 then c - 1 else 0) 0 fields `zip` [0..]
ipv6Any :: IPv6
ipv6Any = IPv6 0 0 0 0
ipv6Loopback :: IPv6
ipv6Loopback = IPv6 0 0 0 1
ipv6AddrToTuple :: IPv6 -> (Word16, Word16, Word16, Word16,
Word16, Word16, Word16, Word16)
ipv6AddrToTuple (IPv6 w3 w2 w1 w0) =
let high, low :: Word32 -> Word16
high w = fromIntegral (w `shiftR` 16)
low w = fromIntegral w
in (high w3, low w3, high w2, low w2, high w1, low w1, high w0, low w0)
tupleToIPv6Addr :: (Word16, Word16, Word16, Word16,
Word16, Word16, Word16, Word16) -> IPv6
tupleToIPv6Addr (w7, w6, w5, w4, w3, w2, w1, w0) =
let add :: Word16 -> Word16 -> Word32
high `add` low = (fromIntegral high `shiftL` 16) .|. (fromIntegral low)
in IPv6 (w7 `add` w6) (w5 `add` w4) (w3 `add` w2) (w1 `add` w0)
instance Storable IPv6 where
sizeOf _ = (16)
{-# LINE 380 "Z/IO/Network/SocketAddr.hsc" #-}
alignment _ = 4
{-# LINE 381 "Z/IO/Network/SocketAddr.hsc" #-}
peek p = do
a <- peek32 p 0
b <- peek32 p 1
c <- peek32 p 2
d <- peek32 p 3
return $ IPv6 a b c d
poke p (IPv6 a b c d) = do
poke32 p 0 a
poke32 p 1 b
poke32 p 2 c
poke32 p 3 d
s6_addr_offset :: Int
s6_addr_offset = ((0))
{-# LINE 396 "Z/IO/Network/SocketAddr.hsc" #-}
peek32 :: Ptr a -> Int -> IO Word32
peek32 p i0 = do
let i' = i0 * 4
peekByte n = peekByteOff p (s6_addr_offset + i' + n) :: IO Word8
a `sl` i = fromIntegral a `shiftL` i
a0 <- peekByte 0
a1 <- peekByte 1
a2 <- peekByte 2
a3 <- peekByte 3
return ((a0 `sl` 24) .|. (a1 `sl` 16) .|. (a2 `sl` 8) .|. (a3 `sl` 0))
poke32 :: Ptr a -> Int -> Word32 -> IO ()
poke32 p i0 a = do
let i' = i0 * 4
pokeByte n = pokeByteOff p (s6_addr_offset + i' + n)
x `sr` i = fromIntegral (x `shiftR` i) :: Word8
pokeByte 0 (a `sr` 24)
pokeByte 1 (a `sr` 16)
pokeByte 2 (a `sr` 8)
pokeByte 3 (a `sr` 0)
instance Unaligned IPv6 where
unalignedSize _ = ((16))
{-# LINE 420 "Z/IO/Network/SocketAddr.hsc" #-}
indexBA p off =
let a = indexBA p (off + s6_addr_offset + 0)
b = indexBA p (off + s6_addr_offset + 4)
c = indexBA p (off + s6_addr_offset + 8)
d = indexBA p (off + s6_addr_offset + 12)
in IPv6 (getBE a) (getBE b) (getBE c) (getBE d)
peekMBA p off = do
a <- peekMBA p (off + s6_addr_offset + 0)
b <- peekMBA p (off + s6_addr_offset + 4)
c <- peekMBA p (off + s6_addr_offset + 8)
d <- peekMBA p (off + s6_addr_offset + 12)
return $ IPv6 (getBE a) (getBE b) (getBE c) (getBE d)
pokeMBA p off (IPv6 a b c d) = do
pokeMBA p (off + s6_addr_offset) (BE a)
pokeMBA p (off + 4 + s6_addr_offset) (BE b)
pokeMBA p (off + 8 + s6_addr_offset) (BE c)
pokeMBA p (off + 12 + s6_addr_offset) (BE d)
peekSocketAddr :: HasCallStack => Ptr SocketAddr -> IO SocketAddr
peekSocketAddr p = do
family <- ((\hsc_ptr -> peekByteOff hsc_ptr 0)) p
{-# LINE 446 "Z/IO/Network/SocketAddr.hsc" #-}
case family :: CSaFamily of
(2) -> do
{-# LINE 448 "Z/IO/Network/SocketAddr.hsc" #-}
addr <- ((\hsc_ptr -> peekByteOff hsc_ptr 4)) p
{-# LINE 449 "Z/IO/Network/SocketAddr.hsc" #-}
port <- ((\hsc_ptr -> peekByteOff hsc_ptr 2)) p
{-# LINE 450 "Z/IO/Network/SocketAddr.hsc" #-}
return (SocketAddrIPv4 addr port)
(10) -> do
{-# LINE 452 "Z/IO/Network/SocketAddr.hsc" #-}
port <- ((\hsc_ptr -> peekByteOff hsc_ptr 2)) p
{-# LINE 453 "Z/IO/Network/SocketAddr.hsc" #-}
flow <- ((\hsc_ptr -> peekByteOff hsc_ptr 4)) p
{-# LINE 454 "Z/IO/Network/SocketAddr.hsc" #-}
addr <- ((\hsc_ptr -> peekByteOff hsc_ptr 8)) p
{-# LINE 455 "Z/IO/Network/SocketAddr.hsc" #-}
scope <- ((\hsc_ptr -> peekByteOff hsc_ptr 24)) p
{-# LINE 456 "Z/IO/Network/SocketAddr.hsc" #-}
return (SocketAddrIPv6 addr port flow scope)
_ -> do let errno = UV_EAI_ADDRFAMILY
name <- uvErrName errno
desc <- uvStdError errno
throwUVError errno (IOEInfo name desc callStack)
pokeSocketAddr :: Ptr SocketAddr -> SocketAddr -> IO ()
pokeSocketAddr p (SocketAddrIPv4 addr port) = do
{-# LINE 467 "Z/IO/Network/SocketAddr.hsc" #-}
{-# LINE 470 "Z/IO/Network/SocketAddr.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 0)) p ((2) :: CSaFamily)
{-# LINE 471 "Z/IO/Network/SocketAddr.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 2)) p port
{-# LINE 472 "Z/IO/Network/SocketAddr.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 4)) p addr
{-# LINE 473 "Z/IO/Network/SocketAddr.hsc" #-}
pokeSocketAddr p (SocketAddrIPv6 addr port flow scope) = do
{-# LINE 477 "Z/IO/Network/SocketAddr.hsc" #-}
{-# LINE 480 "Z/IO/Network/SocketAddr.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 0)) p ((10) :: CSaFamily)
{-# LINE 481 "Z/IO/Network/SocketAddr.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 2)) p port
{-# LINE 482 "Z/IO/Network/SocketAddr.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 4)) p flow
{-# LINE 483 "Z/IO/Network/SocketAddr.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 8)) p (addr)
{-# LINE 484 "Z/IO/Network/SocketAddr.hsc" #-}
((\hsc_ptr -> pokeByteOff hsc_ptr 24)) p scope
{-# LINE 485 "Z/IO/Network/SocketAddr.hsc" #-}
withSocketAddr :: SocketAddr -> (Ptr SocketAddr -> IO a) -> IO a
withSocketAddr sa@(SocketAddrIPv4 _ _) f = do
allocaBytesAligned
((16))
{-# LINE 493 "Z/IO/Network/SocketAddr.hsc" #-}
(4) $ \ p -> pokeSocketAddr p sa >> f p
{-# LINE 494 "Z/IO/Network/SocketAddr.hsc" #-}
withSocketAddr sa@(SocketAddrIPv6 _ _ _ _) f = do
allocaBytesAligned
((28))
{-# LINE 497 "Z/IO/Network/SocketAddr.hsc" #-}
(4) $ \ p -> pokeSocketAddr p sa >> f p
{-# LINE 498 "Z/IO/Network/SocketAddr.hsc" #-}
withSocketAddrUnsafe :: SocketAddr -> (MBA# SocketAddr -> IO a) -> IO a
withSocketAddrUnsafe sa@(SocketAddrIPv4 _ _) f = do
(MutableByteArray p) <- newByteArray ((16))
{-# LINE 506 "Z/IO/Network/SocketAddr.hsc" #-}
pokeSocketAddrMBA p sa
f p
withSocketAddrUnsafe sa@(SocketAddrIPv6 _ _ _ _) f = do
(MutableByteArray p) <- newByteArray ((28))
{-# LINE 510 "Z/IO/Network/SocketAddr.hsc" #-}
pokeSocketAddrMBA p sa
f p
sizeOfSocketAddr :: SocketAddr -> CSize
sizeOfSocketAddr (SocketAddrIPv4 _ _) = (16)
{-# LINE 515 "Z/IO/Network/SocketAddr.hsc" #-}
sizeOfSocketAddr (SocketAddrIPv6 _ _ _ _) = (28)
{-# LINE 516 "Z/IO/Network/SocketAddr.hsc" #-}
withSocketAddrStorage :: (Ptr SocketAddr -> IO ()) -> IO SocketAddr
withSocketAddrStorage f = do
allocaBytesAligned
((128))
{-# LINE 522 "Z/IO/Network/SocketAddr.hsc" #-}
(8) $ \ p -> f p >> peekSocketAddr p
{-# LINE 523 "Z/IO/Network/SocketAddr.hsc" #-}
withSocketAddrStorageUnsafe :: (MBA# SocketAddr -> IO ()) -> IO SocketAddr
withSocketAddrStorageUnsafe f = do
(MutableByteArray p) <- newByteArray ((128))
{-# LINE 531 "Z/IO/Network/SocketAddr.hsc" #-}
f p
peekSocketAddrMBA p
sizeOfSocketAddrStorage :: CSize
sizeOfSocketAddrStorage = ((128))
{-# LINE 536 "Z/IO/Network/SocketAddr.hsc" #-}
peekSocketAddrMBA :: HasCallStack => MBA# SocketAddr -> IO SocketAddr
peekSocketAddrMBA p = do
family <- peekMBA p ((0))
{-# LINE 540 "Z/IO/Network/SocketAddr.hsc" #-}
case family :: CSaFamily of
(2) -> do
{-# LINE 542 "Z/IO/Network/SocketAddr.hsc" #-}
addr <- peekMBA p ((4))
{-# LINE 543 "Z/IO/Network/SocketAddr.hsc" #-}
port <- peekMBA p ((2))
{-# LINE 544 "Z/IO/Network/SocketAddr.hsc" #-}
return (SocketAddrIPv4 addr port)
(10) -> do
{-# LINE 546 "Z/IO/Network/SocketAddr.hsc" #-}
port <- peekMBA p ((2))
{-# LINE 547 "Z/IO/Network/SocketAddr.hsc" #-}
flow <- peekMBA p ((4))
{-# LINE 548 "Z/IO/Network/SocketAddr.hsc" #-}
addr <- peekMBA p ((8))
{-# LINE 549 "Z/IO/Network/SocketAddr.hsc" #-}
scope <- peekMBA p ((24))
{-# LINE 550 "Z/IO/Network/SocketAddr.hsc" #-}
return (SocketAddrIPv6 addr port flow scope)
_ -> do let errno = UV_EAI_ADDRFAMILY
name <- uvErrName errno
desc <- uvStdError errno
throwUVError errno (IOEInfo name desc callStack)
pokeSocketAddrMBA :: MBA# SocketAddr -> SocketAddr -> IO ()
pokeSocketAddrMBA p (SocketAddrIPv4 addr port) = do
{-# LINE 561 "Z/IO/Network/SocketAddr.hsc" #-}
{-# LINE 564 "Z/IO/Network/SocketAddr.hsc" #-}
pokeMBA p ((0)) ((2) :: CSaFamily)
{-# LINE 565 "Z/IO/Network/SocketAddr.hsc" #-}
pokeMBA p ((2)) port
{-# LINE 566 "Z/IO/Network/SocketAddr.hsc" #-}
pokeMBA p ((4)) addr
{-# LINE 567 "Z/IO/Network/SocketAddr.hsc" #-}
pokeSocketAddrMBA p (SocketAddrIPv6 addr port flow scope) = do
{-# LINE 571 "Z/IO/Network/SocketAddr.hsc" #-}
{-# LINE 574 "Z/IO/Network/SocketAddr.hsc" #-}
pokeMBA p ((0)) ((10) :: CSaFamily)
{-# LINE 575 "Z/IO/Network/SocketAddr.hsc" #-}
pokeMBA p ((2)) port
{-# LINE 576 "Z/IO/Network/SocketAddr.hsc" #-}
pokeMBA p ((4)) flow
{-# LINE 577 "Z/IO/Network/SocketAddr.hsc" #-}
pokeMBA p ((8)) (addr)
{-# LINE 578 "Z/IO/Network/SocketAddr.hsc" #-}
pokeMBA p ((24)) scope
{-# LINE 579 "Z/IO/Network/SocketAddr.hsc" #-}
newtype PortNumber = PortNumber Word16
deriving (Eq, Ord, Enum, Generic)
deriving newtype (Show, ShowT, Read, Num, Bounded, Real, Integral, EncodeJSON, ToValue, FromValue)
portAny :: PortNumber
portAny = PortNumber 0
instance Storable PortNumber where
sizeOf _ = sizeOf (0 :: Word16)
alignment _ = alignment (0 :: Word16)
poke p (PortNumber po) = poke (castPtr p) (htons po)
peek p = PortNumber . ntohs <$> peek (castPtr p)
instance Unaligned PortNumber where
unalignedSize _ = 2
indexBA p off = PortNumber . ntohs $ indexBA p off
pokeMBA p off (PortNumber po) = pokeMBA p off (htons po)
peekMBA p off = PortNumber . ntohs <$> peekMBA p off
type SocketFamily = CInt
type SocketType = CInt
type ProtocolNumber = CInt
pattern AF_UNSPEC :: SocketFamily
pattern AF_UNSPEC = 0
{-# LINE 628 "Z/IO/Network/SocketAddr.hsc" #-}
pattern AF_INET :: SocketFamily
pattern AF_INET = 2
{-# LINE 631 "Z/IO/Network/SocketAddr.hsc" #-}
pattern AF_INET6 :: SocketFamily
pattern AF_INET6 = 10
{-# LINE 634 "Z/IO/Network/SocketAddr.hsc" #-}
pattern SOCK_STREAM :: SocketType
pattern SOCK_STREAM = 1
{-# LINE 637 "Z/IO/Network/SocketAddr.hsc" #-}
pattern SOCK_DGRAM :: SocketType
pattern SOCK_DGRAM = 2
{-# LINE 639 "Z/IO/Network/SocketAddr.hsc" #-}
pattern SOCK_RAW :: SocketType
pattern SOCK_RAW = 3
{-# LINE 641 "Z/IO/Network/SocketAddr.hsc" #-}
pattern SOCK_RDM :: SocketType
pattern SOCK_RDM = 4
{-# LINE 643 "Z/IO/Network/SocketAddr.hsc" #-}
pattern SOCK_SEQPACKET :: SocketType
pattern SOCK_SEQPACKET = 5
{-# LINE 645 "Z/IO/Network/SocketAddr.hsc" #-}
pattern SOCK_ANY :: SocketType
pattern SOCK_ANY = 0
pattern IPPROTO_DEFAULT :: ProtocolNumber
pattern IPPROTO_DEFAULT = 0
pattern IPPROTO_IP :: ProtocolNumber
pattern IPPROTO_IP = 0
{-# LINE 653 "Z/IO/Network/SocketAddr.hsc" #-}
pattern IPPROTO_TCP :: ProtocolNumber
pattern IPPROTO_TCP = 6
{-# LINE 655 "Z/IO/Network/SocketAddr.hsc" #-}
pattern IPPROTO_UDP :: ProtocolNumber
pattern IPPROTO_UDP = 17
{-# LINE 657 "Z/IO/Network/SocketAddr.hsc" #-}
foreign import ccall unsafe "ntohs" ntohs :: Word16 -> Word16
{-# LINE 661 "Z/IO/Network/SocketAddr.hsc" #-}
foreign import ccall unsafe "htons" htons :: Word16 -> Word16
{-# LINE 662 "Z/IO/Network/SocketAddr.hsc" #-}
foreign import ccall unsafe "ntohl" ntohl :: Word32 -> Word32
{-# LINE 663 "Z/IO/Network/SocketAddr.hsc" #-}
foreign import ccall unsafe "htonl" htonl :: Word32 -> Word32
{-# LINE 664 "Z/IO/Network/SocketAddr.hsc" #-}
foreign import ccall unsafe uv_ip4_addr :: BA# Word8 -> CInt -> MBA# SocketAddr -> IO CInt
foreign import ccall unsafe uv_ip6_addr :: BA# Word8 -> CInt -> MBA# SocketAddr -> IO CInt