{-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE TemplateHaskell #-} {-# OPTIONS_HADDOCK hide #-} -- | -- Module : Data.Array.Accelerate.Sugar.Foreign -- Copyright : [2008..2020] The Accelerate Team -- License : BSD3 -- -- Maintainer : Trevor L. McDonell <trevor.mcdonell@gmail.com> -- Stability : experimental -- Portability : non-portable (GHC extensions) -- module Data.Array.Accelerate.Sugar.Foreign where import Data.Array.Accelerate.Error import Data.Typeable import Language.Haskell.TH.Extra -- Class for backends to choose their own representation of foreign functions. -- By default it has no instances. If a backend wishes to have an FFI it must -- provide an instance. -- class Typeable asm => Foreign asm where -- Backends should be able to produce a string representation of the foreign -- function for pretty printing, typically the name of the function. strForeign :: asm args -> String strForeign asm args _ = String "<foreign>" -- Backends which want to support compile-time embedding must be able to lift -- the foreign function into Template Haskell liftForeign :: HasCallStack => asm args -> CodeQ (asm args) liftForeign asm args _ = Format (Code Q (asm args)) (Code Q (asm args)) -> Code Q (asm args) forall r a. HasCallStack => Format r a -> a internalError Format (Code Q (asm args)) (Code Q (asm args)) "not supported by this backend"