-- Hoogle documentation, generated by Haddock -- See Hoogle, http://www.haskell.org/hoogle/ -- | GHC.Generics-based Control.DeepSeq.rnf implementation -- -- This package provides a GHC.Generics-based -- Control.DeepSeq.Generics.genericRnf function which can be used -- for providing a rnf implementation. See the documentation for -- the genericRnf function in the Control.DeepSeq.Generics -- module to get started. -- -- The original idea was pioneered in the generic-deepseq -- package (see -- http://www.haskell.org/pipermail/haskell-cafe/2012-February/099551.html -- for more information). -- -- This package differs from the generic-deepseq package by -- working in combination with the existing deepseq package as -- opposed to defining a conflicting drop-in replacement for -- deepseq's Control.DeepSeq module. -- -- Note: The ability to auto-derive via GHC.Generics has -- been merged into deepseq-1.4.0.0. This package is now still -- useful for writing code that's also compatible with older -- deepseq versions not yet providing -- GHC.Generics-support. @package deepseq-generics @version 0.2.0.0 -- | NOTE: Starting with deepseq-1.4.0.0, NFData -- gained support for generic derivation via DefaultSignatures. -- The new default rnf method implementation is then equivalent to -- --
--   instance NFData MyType where
--     rnf = genericRnfV1
--   
-- -- See documentation of rnf for more details on how to use the new -- built-in Generic support. module Control.DeepSeq.Generics -- | GHC.Generics-based rnf implementation -- -- This provides a generic rnf implementation for one type at a -- time. If the type of the value genericRnf is asked to reduce to -- NF contains values of other types, those types have to provide -- NFData instances. This also means that recursive types can only -- be used with genericRnf if a NFData instance has been -- defined as well (see examples below). -- -- The typical usage for genericRnf is for reducing boilerplate -- code when defining NFData instances for ordinary algebraic -- datatypes. See the code below for some simple usage examples: -- --
--   {-# LANGUAGE DeriveGeneric #-}
--   
--   import Control.DeepSeq
--   import Control.DeepSeq.Generics (genericRnf)
--   import GHC.Generics
--   
--   -- simple record
--   data Foo = Foo AccountId Name Address
--            deriving Generic
--   
--   type Address      = [String]
--   type Name         = String
--   newtype AccountId = AccountId Int
--   
--   instance NFData AccountId
--   instance NFData Foo where rnf = genericRnf
--   
--   -- recursive list-like type
--   data N = Z | S N deriving Generic
--   
--   instance NFData N where rnf = genericRnf
--   
--   -- parametric & recursive type
--   data Bar a = Bar0 | Bar1 a | Bar2 (Bar a)
--              deriving Generic
--   
--   instance NFData a => NFData (Bar a) where rnf = genericRnf
--   
-- -- NOTE: The GNFData type-class showing up in the -- type-signature is used internally and not exported. genericRnf :: (Generic a, GNFData (Rep a)) => a -> () -- | Variant of genericRnf which supports derivation for uninhabited -- types. -- -- For instance, the type -- --
--   data TagFoo deriving Generic
--   
-- -- would cause a compile-time error with genericRnf, but with -- genericRnfV1 the error is deferred to run-time: -- --
--   Prelude> genericRnf (undefined :: TagFoo)
--   
--   <interactive>:1:1:
--       No instance for (GNFData V1) arising from a use of `genericRnf'
--       Possible fix: add an instance declaration for (GNFData V1)
--       In the expression: genericRnf (undefined :: TagFoo)
--       In an equation for `it': it = genericRnf (undefined :: TagFoo)
--   
--   Prelude> genericRnfV1 (undefined :: TagFoo)
--   *** Exception: Control.DeepSeq.Generics.genericRnfV1: uninhabited type
--   
-- -- genericRnfV1 corresponds to deepseq-1.4.0.0's default -- rnf method implementation. -- -- NOTE: The GNFDataV1 type-class showing up in the -- type-signature is used internally and not exported. genericRnfV1 :: (Generic a, GNFDataV1 (Rep a)) => a -> () instance Control.DeepSeq.Generics.GNFData GHC.Generics.U1 instance Control.DeepSeq.NFData a => Control.DeepSeq.Generics.GNFData (GHC.Generics.K1 i a) instance Control.DeepSeq.Generics.GNFData a => Control.DeepSeq.Generics.GNFData (GHC.Generics.M1 i c a) instance (Control.DeepSeq.Generics.GNFData a, Control.DeepSeq.Generics.GNFData b) => Control.DeepSeq.Generics.GNFData (a GHC.Generics.:*: b) instance (Control.DeepSeq.Generics.GNFData a, Control.DeepSeq.Generics.GNFData b) => Control.DeepSeq.Generics.GNFData (a GHC.Generics.:+: b) instance Control.DeepSeq.Generics.GNFDataV1 GHC.Generics.V1 instance Control.DeepSeq.Generics.GNFDataV1 GHC.Generics.U1 instance Control.DeepSeq.NFData a => Control.DeepSeq.Generics.GNFDataV1 (GHC.Generics.K1 i a) instance Control.DeepSeq.Generics.GNFDataV1 a => Control.DeepSeq.Generics.GNFDataV1 (GHC.Generics.M1 i c a) instance (Control.DeepSeq.Generics.GNFDataV1 a, Control.DeepSeq.Generics.GNFDataV1 b) => Control.DeepSeq.Generics.GNFDataV1 (a GHC.Generics.:*: b) instance (Control.DeepSeq.Generics.GNFDataV1 a, Control.DeepSeq.Generics.GNFDataV1 b) => Control.DeepSeq.Generics.GNFDataV1 (a GHC.Generics.:+: b)