1
0
forked from GitHub/gf-core

Added inferExpr to py-bindings.

This commit is contained in:
jordi.saludes
2010-07-27 07:50:48 +00:00
parent 1209cd8f9e
commit b9de5c36c0
3 changed files with 43 additions and 4 deletions

View File

@@ -219,6 +219,13 @@ gf_unstr pexp = do
Just s -> newCString s
_ -> return nullPtr
foreign export ccall gf_inferexpr :: Ptr PGF -> Ptr Expr -> Ptr Type -> IO ()
gf_inferexpr ppgf pexp ptype = do
pgf <- peek ppgf
exp <- peek pexp
let Right (_,t) = inferExpr pgf exp
poke ptype t
foreign import ccall "newLang" pyLang :: IO (Ptr Language)
foreign import ccall "newTree" pyTree :: IO (Ptr Tree)
foreign import ccall "newCId" pyCId :: IO (Ptr CId)

View File

@@ -245,13 +245,33 @@ unapp(Expr *self) {
return obj;
}
static PyObject*
infer_expr(Expr *self, PyObject* args) {
PGF* pgf;
if (!PyArg_ParseTuple(args, "O", &pgf))
return NULL;
if (!checkType(pgf, &PGFType)) {
PyErr_Format(PyExc_ValueError, "Must be a pgf module.");
return NULL;
}
gfType* gftp = (gfType*)gfTypeType.tp_new(&gfTypeType,NULL,NULL);
gf_inferexpr(pgf, self, gftp);
return gftp;
}
/* todo: Is Tree == Expr ?
static PyMethodDef tree_methods[] = {
{"unapply", (PyCFunction)unapp, METH_NOARGS,"Unapply a tree."},
{NULL, NULL, 0, NULL} /* Sentinel */
{"unapply", (PyCFunction)unapp, METH_NOARGS, "Unapply a tree."},
{NULL, NULL, 0, NULL} // * Sentinel * //
};
*/
static PyMethodDef expr_methods[] = {
{"unapply", (PyCFunction)unapp, METH_NOARGS,"Unapply an expression."},
{"unapply", (PyCFunction)unapp, METH_NOARGS, "Unapply an expression."},
{"infer", (PyCFunction)infer_expr, METH_VARARGS, "Infer the type of an expression."},
{NULL, NULL, 0, NULL} /* Sentinel */
};
@@ -297,7 +317,7 @@ initgf(void)
READYTYPE(gfTypeType, gfType_repr, gfType_dealloc)
ExprType.tp_methods = expr_methods;
READYTYPE(ExprType, expr_repr, expr_dealloc)
TreeType.tp_methods = tree_methods;
TreeType.tp_methods = expr_methods; // Tree == Expr ?
READYTYPE(TreeType, tree_repr, Tree_dealloc)
m = Py_InitModule3("gf", gf_methods,

View File

@@ -142,5 +142,17 @@ class TestUnapplyExpr(unittest.TestCase):
uparsed = self.deep_unapp(parsed[0])
self.assertEqual(abs,uparsed)
def test_infer(self):
lg = 'eng'
lang = self.langs[lg]
cnc = self.samples[0][1]
parsed = self.pgf.parse(cnc[lg],lang)
exp = parsed[0]
for t in 'Question Object Int'.split():
self.assertEqual(`exp.infer(self.pgf)`, t)
uexp = exp.unapply()
if type(uexp) != type(2) and type(uexp) != type('2'):
exp = uexp[1]
if __name__ == '__main__':
unittest.main()