module Data.Array.Accelerate.Analysis.Hash.TH (
hashQ,
hashWithSaltQ,
) where
import Data.Hashable
import Language.Haskell.TH
hashQ :: Hashable a => a -> ExpQ
hashQ :: forall a. Hashable a => a -> ExpQ
hashQ = Int -> ExpQ
intE (Int -> ExpQ) -> (a -> Int) -> a -> ExpQ
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> Int
forall a. Hashable a => a -> Int
hash
hashWithSaltQ :: Hashable a => Int -> a -> ExpQ
hashWithSaltQ :: forall a. Hashable a => Int -> a -> ExpQ
hashWithSaltQ Int
s a
x = Int -> ExpQ
intE (Int -> a -> Int
forall a. Hashable a => Int -> a -> Int
hashWithSalt Int
s a
x)
intE :: Int -> ExpQ
intE :: Int -> ExpQ
intE = Lit -> ExpQ
forall (m :: * -> *). Quote m => Lit -> m Exp
litE (Lit -> ExpQ) -> (Int -> Lit) -> Int -> ExpQ
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Integer -> Lit
integerL (Integer -> Lit) -> (Int -> Integer) -> Int -> Lit
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Int -> Integer
forall a b. (Integral a, Num b) => a -> b
fromIntegral