Copyright | (c) The University of Glasgow 2001-2009 |
---|---|
License | BSD-style (see the file LICENSE) |
Maintainer | [email protected] |
Stability | stable |
Portability | portable |
Safe Haskell | Safe |
Language | Haskell2010 |
This module provides overloaded functions, such as deepseq
and
rnf
, for fully evaluating data structures (that is, evaluating to
"Normal Form").
A typical use is to prevent resource leaks in lazy IO programs, by forcing all characters from a file to be read. For example:
import System.IO import Control.DeepSeq import Control.Exception (evaluate) readFile' :: FilePath -> IO String readFile' fn = do h <- openFile fn ReadMode s <- hGetContents h evaluate (rnf s) hClose h return s
Note: The example above should rather be written in terms of
bracket
to ensure releasing file-descriptors in
a timely matter (see the description of force
for an example).
deepseq
differs from seq
as it traverses data structures deeply,
for example, seq
will evaluate only to the first constructor in
the list:
> [1,2,undefined] `seq` 3 3
While deepseq
will force evaluation of all the list elements:
> [1,2,undefined] `deepseq` 3 *** Exception: Prelude.undefined
Another common use is to ensure any exceptions hidden within lazy fields of a data structure do not leak outside the scope of the exception handler, or to force evaluation of a data structure in one thread, before passing to another thread (preventing work moving to the wrong threads).
Since: deepseq-1.1.0.0
Synopsis
- class NFData a where
- deepseq :: NFData a => a -> b -> b
- force :: NFData a => a -> a
- ($!!) :: NFData a => (a -> b) -> a -> b
- (<$!!>) :: (Monad m, NFData b) => (a -> b) -> m a -> m b
- rwhnf :: a -> ()
- class NFData1 f where
- rnf1 :: (NFData1 f, NFData a) => f a -> ()
- class NFData2 p where
- rnf2 :: (NFData2 p, NFData a, NFData b) => p a b -> ()
NFData
class
A class of types that can be fully evaluated.
Since: deepseq-1.1.0.0
rnf
should reduce its argument to normal form (that is, fully
evaluate all sub-components), and then return '()'.
Generic
NFData
deriving
Starting with GHC 7.2, you can automatically derive instances
for types possessing a Generic
instance.
Note: Generic1
can be auto-derived starting with GHC 7.4
{-# LANGUAGE DeriveGeneric #-} import GHC.Generics (Generic, Generic1) import Control.DeepSeq data Foo a = Foo a String deriving (Eq, Generic, Generic1) instance NFData a => NFData (Foo a) instance NFData1 Foo data Colour = Red | Green | Blue deriving Generic instance NFData Colour
Starting with GHC 7.10, the example above can be written more
concisely by enabling the new DeriveAnyClass
extension:
{-# LANGUAGE DeriveGeneric, DeriveAnyClass #-} import GHC.Generics (Generic) import Control.DeepSeq data Foo a = Foo a String deriving (Eq, Generic, Generic1, NFData, NFData1) data Colour = Red | Green | Blue deriving (Generic, NFData)
Compatibility with previous deepseq
versions
Prior to version 1.4.0.0, the default implementation of the rnf
method was defined as
rnf
a =seq
a ()
However, starting with deepseq-1.4.0.0
, the default
implementation is based on DefaultSignatures
allowing for
more accurate auto-derived NFData
instances. If you need the
previously used exact default rnf
method implementation
semantics, use
instance NFData Colour where rnf x = seq x ()
or alternatively
instance NFData Colour where rnf = rwhnf
or
{-# LANGUAGE BangPatterns #-} instance NFData Colour where rnf !_ = ()
rnf :: (Generic a, GNFData Zero (Rep a)) => a -> () Source #
rnf
should reduce its argument to normal form (that is, fully
evaluate all sub-components), and then return '()'.
Generic
NFData
deriving
Starting with GHC 7.2, you can automatically derive instances
for types possessing a Generic
instance.
Note: Generic1
can be auto-derived starting with GHC 7.4
{-# LANGUAGE DeriveGeneric #-} import GHC.Generics (Generic, Generic1) import Control.DeepSeq data Foo a = Foo a String deriving (Eq, Generic, Generic1) instance NFData a => NFData (Foo a) instance NFData1 Foo data Colour = Red | Green | Blue deriving Generic instance NFData Colour
Starting with GHC 7.10, the example above can be written more
concisely by enabling the new DeriveAnyClass
extension:
{-# LANGUAGE DeriveGeneric, DeriveAnyClass #-} import GHC.Generics (Generic) import Control.DeepSeq data Foo a = Foo a String deriving (Eq, Generic, Generic1, NFData, NFData1) data Colour = Red | Green | Blue deriving (Generic, NFData)
Compatibility with previous deepseq
versions
Prior to version 1.4.0.0, the default implementation of the rnf
method was defined as
rnf
a =seq
a ()
However, starting with deepseq-1.4.0.0
, the default
implementation is based on DefaultSignatures
allowing for
more accurate auto-derived NFData
instances. If you need the
previously used exact default rnf
method implementation
semantics, use
instance NFData Colour where rnf x = seq x ()
or alternatively
instance NFData Colour where rnf = rwhnf
or
{-# LANGUAGE BangPatterns #-} instance NFData Colour where rnf !_ = ()
Instances
NFData Bool # | |
Defined in Control.DeepSeq | |
NFData Char # | |
Defined in Control.DeepSeq | |
NFData Double # | |
Defined in Control.DeepSeq | |
NFData Float # | |
Defined in Control.DeepSeq | |
NFData Int # | |
Defined in Control.DeepSeq | |
NFData Int8 # | |
Defined in Control.DeepSeq | |
NFData Int16 # | |
Defined in Control.DeepSeq | |
NFData Int32 # | |
Defined in Control.DeepSeq | |
NFData Int64 # | |
Defined in Control.DeepSeq | |
NFData Integer # | |
Defined in Control.DeepSeq | |
NFData Natural # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData Ordering # | |
Defined in Control.DeepSeq | |
NFData Word # | |
Defined in Control.DeepSeq | |
NFData Word8 # | |
Defined in Control.DeepSeq | |
NFData Word16 # | |
Defined in Control.DeepSeq | |
NFData Word32 # | |
Defined in Control.DeepSeq | |
NFData Word64 # | |
Defined in Control.DeepSeq | |
NFData CallStack # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData () # | |
Defined in Control.DeepSeq | |
NFData TyCon # | NOTE: Only defined for Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData Void # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData Unique # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData Version # | Since: deepseq-1.3.0.0 |
Defined in Control.DeepSeq | |
NFData ThreadId # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData ExitCode # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData TypeRep # | NOTE: Only defined for Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData All # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData Any # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CChar # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CSChar # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CUChar # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CShort # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CUShort # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CInt # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CUInt # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CLong # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CULong # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CLLong # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CULLong # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CBool # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData CFloat # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CDouble # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CPtrdiff # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CSize # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CWchar # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CSigAtomic # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq rnf :: CSigAtomic -> () Source # | |
NFData CClock # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CTime # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CUSeconds # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CSUSeconds # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq rnf :: CSUSeconds -> () Source # | |
NFData CFile # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CFpos # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CJmpBuf # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CIntPtr # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CUIntPtr # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CIntMax # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData CUIntMax # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData Fingerprint # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq rnf :: Fingerprint -> () Source # | |
NFData SrcLoc # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData a => NFData [a] # | |
Defined in Control.DeepSeq | |
NFData a => NFData (Maybe a) # | |
Defined in Control.DeepSeq | |
NFData a => NFData (Ratio a) # | |
Defined in Control.DeepSeq | |
NFData (Ptr a) # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData (FunPtr a) # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (Complex a) # | |
Defined in Control.DeepSeq | |
NFData (Fixed a) # | Since: deepseq-1.3.0.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (Min a) # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (Max a) # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (First a) # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (Last a) # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData m => NFData (WrappedMonoid m) # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq rnf :: WrappedMonoid m -> () Source # | |
NFData a => NFData (Option a) # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData (StableName a) # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq rnf :: StableName a -> () Source # | |
NFData a => NFData (ZipList a) # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (Identity a) # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData (IORef a) # | NOTE: Only strict in the reference and not the referenced value. Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (First a) # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (Last a) # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (Dual a) # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (Sum a) # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (Product a) # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (Down a) # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData (MVar a) # | NOTE: Only strict in the reference and not the referenced value. Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData a => NFData (NonEmpty a) # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData (a -> b) # | This instance is for convenience and consistency with Since: deepseq-1.3.0.0 |
Defined in Control.DeepSeq | |
(NFData a, NFData b) => NFData (Either a b) # | |
Defined in Control.DeepSeq | |
(NFData a, NFData b) => NFData (a, b) # | |
Defined in Control.DeepSeq | |
(NFData a, NFData b) => NFData (Array a b) # | |
Defined in Control.DeepSeq | |
(NFData a, NFData b) => NFData (Arg a b) # | Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
NFData (Proxy a) # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData (STRef s a) # | NOTE: Only strict in the reference and not the referenced value. Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3) => NFData (a1, a2, a3) # | |
Defined in Control.DeepSeq | |
NFData a => NFData (Const a b) # | Since: deepseq-1.4.0.0 |
Defined in Control.DeepSeq | |
NFData (a :~: b) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4) => NFData (a1, a2, a3, a4) # | |
Defined in Control.DeepSeq | |
(NFData1 f, NFData1 g, NFData a) => NFData (Product f g a) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData1 f, NFData1 g, NFData a) => NFData (Sum f g a) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData (a :~~: b) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5) => NFData (a1, a2, a3, a4, a5) # | |
Defined in Control.DeepSeq | |
(NFData1 f, NFData1 g, NFData a) => NFData (Compose f g a) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5, NFData a6) => NFData (a1, a2, a3, a4, a5, a6) # | |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5, NFData a6, NFData a7) => NFData (a1, a2, a3, a4, a5, a6, a7) # | |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5, NFData a6, NFData a7, NFData a8) => NFData (a1, a2, a3, a4, a5, a6, a7, a8) # | |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5, NFData a6, NFData a7, NFData a8, NFData a9) => NFData (a1, a2, a3, a4, a5, a6, a7, a8, a9) # | |
Defined in Control.DeepSeq |
Helper functions
deepseq :: NFData a => a -> b -> b Source #
deepseq
: fully evaluates the first argument, before returning the
second.
The name deepseq
is used to illustrate the relationship to seq
:
where seq
is shallow in the sense that it only evaluates the top
level of its argument, deepseq
traverses the entire data structure
evaluating it completely.
deepseq
can be useful for forcing pending exceptions,
eradicating space leaks, or forcing lazy I/O to happen. It is
also useful in conjunction with parallel Strategies (see the
parallel
package).
There is no guarantee about the ordering of evaluation. The
implementation may evaluate the components of the structure in
any order or in parallel. To impose an actual order on
evaluation, use pseq
from Control.Parallel in the
parallel
package.
Since: deepseq-1.1.0.0
force :: NFData a => a -> a Source #
a variant of deepseq
that is useful in some circumstances:
force x = x `deepseq` x
force x
fully evaluates x
, and then returns it. Note that
force x
only performs evaluation when the value of force x
itself is demanded, so essentially it turns shallow evaluation into
deep evaluation.
force
can be conveniently used in combination with ViewPatterns
:
{-# LANGUAGE BangPatterns, ViewPatterns #-} import Control.DeepSeq someFun :: ComplexData -> SomeResult someFun (force -> !arg) = {- 'arg' will be fully evaluated -}
Another useful application is to combine force
with
evaluate
in order to force deep evaluation
relative to other IO
operations:
import Control.Exception (evaluate) import Control.DeepSeq main = do result <- evaluate $ force $ pureComputation {- 'result' will be fully evaluated at this point -} return ()
Finally, here's an exception safe variant of the readFile'
example:
readFile' :: FilePath -> IO String readFile' fn = bracket (openFile fn ReadMode) hClose $ \h -> evaluate . force =<< hGetContents h
Since: deepseq-1.2.0.0
($!!) :: NFData a => (a -> b) -> a -> b infixr 0 Source #
the deep analogue of $!
. In the expression f $!! x
, x
is
fully evaluated before the function f
is applied to it.
Since: deepseq-1.2.0.0
(<$!!>) :: (Monad m, NFData b) => (a -> b) -> m a -> m b infixl 4 Source #
Deeply strict version of <$>
.
Since: deepseq-1.4.3.0
Liftings of the NFData
class
For unary constructors
class NFData1 f where Source #
A class of functors that can be fully evaluated.
Since: deepseq-1.4.3.0
liftRnf :: (a -> ()) -> f a -> () Source #
liftRnf
should reduce its argument to normal form (that is, fully
evaluate all sub-components), given an argument to reduce a
arguments,
and then return '()'.
See rnf
for the generic deriving.
liftRnf :: (Generic1 f, GNFData One (Rep1 f)) => (a -> ()) -> f a -> () Source #
Instances
NFData1 [] # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Maybe # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Ratio # | Available on Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Ptr # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 FunPtr # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Fixed # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Min # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Max # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 First # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Last # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 WrappedMonoid # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq liftRnf :: (a -> ()) -> WrappedMonoid a -> () Source # | |
NFData1 Option # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 StableName # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq liftRnf :: (a -> ()) -> StableName a -> () Source # | |
NFData1 ZipList # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Identity # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 IORef # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 First # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Last # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Dual # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Sum # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Product # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 Down # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 MVar # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 NonEmpty # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData a => NFData1 (Either a) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData a => NFData1 ((,) a) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData a => NFData1 (Array a) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData a => NFData1 (Arg a) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 (Proxy :: * -> *) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 (STRef s) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2) => NFData1 ((,,) a1 a2) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData a => NFData1 (Const a :: * -> *) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 ((:~:) a) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3) => NFData1 ((,,,) a1 a2 a3) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData1 f, NFData1 g) => NFData1 (Product f g) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData1 f, NFData1 g) => NFData1 (Sum f g) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData1 ((:~~:) a :: * -> *) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4) => NFData1 ((,,,,) a1 a2 a3 a4) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData1 f, NFData1 g) => NFData1 (Compose f g) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5) => NFData1 ((,,,,,) a1 a2 a3 a4 a5) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5, NFData a6) => NFData1 ((,,,,,,) a1 a2 a3 a4 a5 a6) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5, NFData a6, NFData a7) => NFData1 ((,,,,,,,) a1 a2 a3 a4 a5 a6 a7) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5, NFData a6, NFData a7, NFData a8) => NFData1 ((,,,,,,,,) a1 a2 a3 a4 a5 a6 a7 a8) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq |
rnf1 :: (NFData1 f, NFData a) => f a -> () Source #
Lift the standard rnf
function through the type constructor.
Since: deepseq-1.4.3.0
For binary constructors
class NFData2 p where Source #
A class of bifunctors that can be fully evaluated.
Since: deepseq-1.4.3.0
Instances
NFData2 Either # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData2 (,) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData2 Array # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData2 Arg # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData2 STRef # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData a1 => NFData2 ((,,) a1) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData2 (Const :: * -> * -> *) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData2 ((:~:) :: * -> * -> *) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2) => NFData2 ((,,,) a1 a2) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
NFData2 ((:~~:) :: * -> * -> *) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3) => NFData2 ((,,,,) a1 a2 a3) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4) => NFData2 ((,,,,,) a1 a2 a3 a4) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5) => NFData2 ((,,,,,,) a1 a2 a3 a4 a5) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5, NFData a6) => NFData2 ((,,,,,,,) a1 a2 a3 a4 a5 a6) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq | |
(NFData a1, NFData a2, NFData a3, NFData a4, NFData a5, NFData a6, NFData a7) => NFData2 ((,,,,,,,,) a1 a2 a3 a4 a5 a6 a7) # | Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq |