{-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RankNTypes #-} {-| Module : HsLua.Class.Invokable Copyright : © 2007–2012 Gracjan Polak, 2012–2016 Ömer Sinan Ağacan, 2017-2023 Albert Krewinkel License : MIT Maintainer : Albert Krewinkel Stability : beta Portability : FlexibleInstances, ForeignFunctionInterface, ScopedTypeVariables Call Lua functions from Haskell. -} module HsLua.Class.Invokable ( Invokable (..) , invoke ) where import Data.ByteString (append) import HsLua.Core as Lua import HsLua.Class.Peekable import HsLua.Class.Pushable import HsLua.Class.Util (popValue) -- | Helper class used to make Lua functions useable from Haskell. class Invokable a where addArg :: Name -> (forall e. LuaError e => LuaE e ()) -> NumArgs -> a instance (LuaError e, Peekable a) => Invokable (LuaE e a) where addArg fnName pushArgs nargs = do _ <- dostring $ "return " `append` Lua.fromName fnName pushArgs call nargs 1 popValue instance (Pushable a, Invokable b) => Invokable (a -> b) where addArg fnName pushArgs nargs x = addArg fnName (pushArgs *> push x) (nargs + 1) -- | Invoke a Lua function. Use as: -- -- > v <- invoke "proc" "abc" (1::Int) (5.0::Double) invoke :: Invokable a => Name -> a invoke fname = addArg fname (return ()) 0