我试图访问XKB API中的各种位和bobs。这是到目前为止我的测试代码:使用hsc2hs与XKB API进行连接
{-# LANGUAGE ForeignFunctionInterface #-}
module Main where
import Foreign
import Foreign.C.Types
#include <X11/XKBlib.h>
#let alignment t = "%lu", (unsigned long)offsetof(struct {char x__; t (y__); }, y__)
data XkbDescRec = XkbDescRec { names :: Ptr XkbNamesRec } deriving (Show)
data XkbNamesRec = XkbNamesRec { groups :: Ptr Word64 } -- Ignore me
foreign import ccall unsafe "X11/XKBlib.h XkbAllocKeyboard"
xkbAllocKeyboard :: IO (Ptr XkbDescRec)
instance Storable XkbDescRec where
sizeOf _ = (#size XkbDescRec)
alignment _ = (#alignment XkbDescRec)
peek ptr = do
names <- (#peek XkbDescRec, names) ptr
return $ XkbDescRec names
main = do
xkbDescPtr <- xkbAllocKeyboard
print xkbDescPtr -- (1)
peek xkbDescPtr >>= print -- (2)
虽然(1)输出0x0000000001777d80
,这听起来像一个有效地址,(2)发射XkbDescRec {names = 0x0000000000000000}
。
我不知道我是否以错误的方式使用FFI,或者我误解了链接中详细描述的XkbDescRec结构的结构。
我开始认为我误解了XkbAllocKeyboard,并始终将该指针初始化为空。如果有人能确认我会很乐意接受。 – Sarah 2014-09-04 21:30:04