added readTriple in libsg and its Haskell binding

This commit is contained in:
krasimir
2015-11-25 10:37:13 +00:00
parent 55cfea35eb
commit 79ea4af960
4 changed files with 39 additions and 3 deletions

View File

@@ -8,7 +8,8 @@ module SG( SG, openSG, closeSG
, beginTrans, commit, rollback, inTransaction
, SgId
, insertExpr, getExpr
, readTriple, insertTriple, getTriple
, readTriple, showTriple
, insertTriple, getTriple
, queryTriple
) where
@@ -128,6 +129,21 @@ readTriple str =
else do gu_pool_free exprPl
return Nothing
showTriple :: Expr -> Expr -> Expr -> String
showTriple (Expr expr1 _) (Expr expr2 _) (Expr expr3 _) =
unsafePerformIO $
withGuPool $ \tmpPl ->
withTriple $ \triple -> do
(sb,out) <- newOut tmpPl
let printCtxt = nullPtr
exn <- gu_new_exn tmpPl
pokeElemOff triple 0 expr1
pokeElemOff triple 1 expr2
pokeElemOff triple 2 expr3
pgf_print_expr_tuple 3 triple printCtxt out exn
s <- gu_string_buf_freeze sb tmpPl
peekCString s
insertTriple :: SG -> Expr -> Expr -> Expr -> IO SgId
insertTriple (SG sg) (Expr expr1 _) (Expr expr2 _) (Expr expr3 _) =
withGuPool $ \tmpPl ->