-- Hoogle documentation, generated by Haddock -- See Hoogle, http://www.haskell.org/hoogle/ -- | Reifies arbitrary terms into types that can be reflected back into terms -- -- This package provides an implementation of the ideas presented in the -- paper "Functional Pearl: Implicit Configurations" by Oleg Kiselyov and -- Chung-chieh Shan. However, the API has been streamlined to improve -- performance. -- -- The original paper can be obtained from -- http://www.cs.rutgers.edu/~ccshan/prepose/prepose.pdf -- -- Changes from 0.5 to 1.1: -- -- -- -- Changes in 0.5: -- -- -- -- Changes in 0.4: -- -- @package reflection @version 1.1.2 -- | Based on the Functional Pearl: Implicit Configurations paper by Oleg -- Kiselyov and Chung-chieh Shan. -- -- http://www.cs.rutgers.edu/~ccshan/prepose/prepose.pdf -- -- The approach from the paper was modified to work with Data.Proxy and -- to cheat by using knowledge of GHC's internal representations by -- Edward Kmett and Elliott Hird. -- -- Usage reduces to using two combinators, reify and -- reflect. -- --
--   ghci> reify 6 (\p -> reflect p + reflect p) :: Int
--   12
--   
-- -- The argument passed along by reify is just a data Proxy t = -- Proxy, so all of the information needed to reconstruct your value -- has been moved to the type level. This enables it to be used when -- constructing instances (see examples/Monoid.hs). module Data.Reflection class Reifies s a | s -> a reflect :: Reifies s a => p s -> a reify :: a -> (forall s. Reifies s a => Proxy s -> w) -> w