module HsLua.Core.Debug
( getupvalue
, setupvalue
) where
import Control.Monad ((<$!>))
import Foreign.C (CString)
import Foreign.Ptr (nullPtr)
import HsLua.Core.Types (LuaE, Name (Name), StackIndex, liftLua)
import Lua.Debug (lua_getupvalue, lua_setupvalue)
import qualified Data.ByteString as B
getupvalue :: StackIndex
-> Int
-> LuaE e (Maybe Name)
getupvalue :: forall e. StackIndex -> Int -> LuaE e (Maybe Name)
getupvalue StackIndex
idx Int
n = (State -> IO (Maybe Name)) -> LuaE e (Maybe Name)
forall a e. (State -> IO a) -> LuaE e a
liftLua ((State -> IO (Maybe Name)) -> LuaE e (Maybe Name))
-> (State -> IO (Maybe Name)) -> LuaE e (Maybe Name)
forall a b. (a -> b) -> a -> b
$ \State
l ->
State -> StackIndex -> CInt -> IO (Ptr CChar)
lua_getupvalue State
l StackIndex
idx (Int -> CInt
forall a b. (Integral a, Num b) => a -> b
fromIntegral Int
n) IO (Ptr CChar) -> (Ptr CChar -> IO (Maybe Name)) -> IO (Maybe Name)
forall a b. IO a -> (a -> IO b) -> IO b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Ptr CChar -> IO (Maybe Name)
toMaybeName
setupvalue :: StackIndex
-> Int
-> LuaE e (Maybe Name)
setupvalue :: forall e. StackIndex -> Int -> LuaE e (Maybe Name)
setupvalue StackIndex
idx Int
n = (State -> IO (Maybe Name)) -> LuaE e (Maybe Name)
forall a e. (State -> IO a) -> LuaE e a
liftLua ((State -> IO (Maybe Name)) -> LuaE e (Maybe Name))
-> (State -> IO (Maybe Name)) -> LuaE e (Maybe Name)
forall a b. (a -> b) -> a -> b
$ \State
l ->
State -> StackIndex -> CInt -> IO (Ptr CChar)
lua_setupvalue State
l StackIndex
idx (Int -> CInt
forall a b. (Integral a, Num b) => a -> b
fromIntegral Int
n) IO (Ptr CChar) -> (Ptr CChar -> IO (Maybe Name)) -> IO (Maybe Name)
forall a b. IO a -> (a -> IO b) -> IO b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Ptr CChar -> IO (Maybe Name)
toMaybeName
toMaybeName :: CString -> IO (Maybe Name)
toMaybeName :: Ptr CChar -> IO (Maybe Name)
toMaybeName Ptr CChar
cstr =
if Ptr CChar
cstr Ptr CChar -> Ptr CChar -> Bool
forall a. Eq a => a -> a -> Bool
== Ptr CChar
forall a. Ptr a
nullPtr
then Maybe Name -> IO (Maybe Name)
forall a. a -> IO a
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe Name
forall a. Maybe a
Nothing
else Name -> Maybe Name
forall a. a -> Maybe a
Just (Name -> Maybe Name)
-> (ByteString -> Name) -> ByteString -> Maybe Name
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ByteString -> Name
Name (ByteString -> Maybe Name) -> IO ByteString -> IO (Maybe Name)
forall (m :: * -> *) a b. Monad m => (a -> b) -> m a -> m b
<$!> Ptr CChar -> IO ByteString
B.packCString Ptr CChar
cstr