{-# INCLUDE <bindings.macros.h> #-}
{-# INCLUDE <time.h> #-}
{-# LINE 1 "src/Bindings/Posix/Time.hsc" #-}

{-# LINE 2 "src/Bindings/Posix/Time.hsc" #-}

{-# LINE 3 "src/Bindings/Posix/Time.hsc" #-}

-- | <http://www.opengroup.org/onlinepubs/9699919799/basedefs/time.h.html>

module Bindings.Posix.Time where
import Prelude (IO,Num,return,(.),($),Eq,Show,take)
import Foreign.Ptr (Ptr,FunPtr,plusPtr)
import Foreign.Ptr (wordPtrToPtr,castPtrToFunPtr)
import Foreign.Storable
import Foreign.C.Types
import Foreign.C.String (CString,CStringLen,CWString,CWStringLen)
import Foreign.Marshal.Array (peekArray,pokeArray)
import Data.Int
import Data.Word

{-# LINE 8 "src/Bindings/Posix/Time.hsc" #-}

data C'timespec = C'timespec{
{-# LINE 10 "src/Bindings/Posix/Time.hsc" #-}

  c'timespec'tv_sec :: CTime
{-# LINE 11 "src/Bindings/Posix/Time.hsc" #-}
,
  c'timespec'tv_nsec :: CLong
{-# LINE 12 "src/Bindings/Posix/Time.hsc" #-}

 } deriving (Eq,Show)
instance Storable C'timespec where
  sizeOf _ = 8
  alignment = sizeOf
  peek p = do
    v0 <- peekByteOff p 0
    v1 <- peekByteOff p 4
    return $ C'timespec v0 v1
  poke p (C'timespec v0 v1) = do
    pokeByteOff p 0 v0
    pokeByteOff p 4 v1
    return ()

{-# LINE 13 "src/Bindings/Posix/Time.hsc" #-}

foreign import ccall "&tzname" p'tzname
  :: Ptr (Ptr CString)

{-# LINE 15 "src/Bindings/Posix/Time.hsc" #-}