summaryrefslogtreecommitdiff
path: root/contrib
diff options
context:
space:
mode:
authorjordi.saludes <jordi.saludes@upc.edu>2010-06-13 16:53:33 +0000
committerjordi.saludes <jordi.saludes@upc.edu>2010-06-13 16:53:33 +0000
commitccbbd4e848ce711c967ca8e98e211c49f5d022fa (patch)
tree88d729f7af7ff3b9627f52647c49a0c9b62de89e /contrib
parent0b1ea70bb6ed29c7a80b471af185ac8f34eca7bf (diff)
Code cleaning on gfmodule
Diffstat (limited to 'contrib')
-rw-r--r--contrib/py-bindings/gfmodule.c161
1 files changed, 91 insertions, 70 deletions
diff --git a/contrib/py-bindings/gfmodule.c b/contrib/py-bindings/gfmodule.c
index 5b5a547c8..e70db604d 100644
--- a/contrib/py-bindings/gfmodule.c
+++ b/contrib/py-bindings/gfmodule.c
@@ -32,45 +32,17 @@
#define NEWGF(OBJ,GFTYPE,TYPE,NAME,DOC) NEWOBJECT(OBJ,GFTYPE) \
NEWTYPE(TYPE,NAME,OBJ,DOC)
+#define DEALLOCFN(delname,t,cb,cbname) static void \
+delname(t *self){ cb(self->obj);\
+ printf("gf_%s has been called for stable pointer 0x%x\n", cbname, self->obj);\
+ self->ob_type->tp_free((PyObject*)self); }
-NEWGF(PGFModule,GF_PGF,PGFType,"gf.pgf","PGF module")
-NEWGF(Lang,GF_Language,LangType,"gf.lang","language")
-NEWGF(gfType,GF_Type,gfTypeType,"gf.type","gf type")
-NEWGF(Expr,GF_Expr,ExprType,"gf.expr","gf expression")
-NEWGF(Tree,GF_Tree,TreeType,"gf.tree","gf tree")
-
-
-static PyObject*
-PGF_repr(PGFModule* obj)
-{
- return PyString_FromFormat("this is a PGF module");
-}
+#define REPRCB(cbid,t,gfcb) static PyObject* \
+cbid(t *self) { \
+ const char *str = gfcb(self->obj); \
+ return PyString_FromFormat("0x%x: %s", self->obj, str); }
-static PGFModule*
-readPGF(PyObject *self, PyObject *args)
-{
- char *path;
- PGFModule *pgf;
- if (!PyArg_ParseTuple(args, "s", &path))
- return NULL;
- pgf = (PGFModule*)PGFType.tp_new(&PGFType,NULL,NULL);
- if (!pgf) return NULL;
- pgf->obj = gf_readPGF(path);
- return pgf;
-}
-
-static Lang*
-readLang(PyObject *self, PyObject *args)
-{
- char *langName;
- Lang *l;
- if (!PyArg_ParseTuple(args,"s",&langName))
- return NULL;
- l = (Lang*)LangType.tp_new(&LangType,NULL,NULL);
- if(!l) return NULL;
- l->obj = gf_readLanguage(langName);
- return l;
-}
+/* utilities */
int
checkType(PyObject* obj, PyTypeObject* tp)
@@ -81,19 +53,19 @@ checkType(PyObject* obj, PyTypeObject* tp)
return isRight;
}
-#define DEALLOCFN(delname,t,cb,cbname) static void \
-delname(t *self){ cb(self->obj);\
- printf("gf_%s has been called for stable pointer 0x%x\n", cbname, self->obj);\
- self->ob_type->tp_free((PyObject*)self); }
+/* new types and declarations */
+NEWGF(Lang,GF_Language,LangType,"gf.lang","language")
+NEWGF(gfType,GF_Type,gfTypeType,"gf.type","gf type")
+NEWGF(PGFModule,GF_PGF,PGFType,"gf.pgf","PGF module")
+NEWGF(Expr,GF_Expr,ExprType,"gf.expr","gf expression")
+NEWGF(Tree,GF_Tree,TreeType,"gf.tree","gf tree")
-DEALLOCFN(gfType_dealloc, gfType, gf_freeType, "freeType")
-DEALLOCFN(PGF_dealloc, PGFModule, gf_freePGF, "freePGF")
-DEALLOCFN(Lang_dealloc, Lang, gf_freeLanguage, "freeLanguage")
-DEALLOCFN(Tree_dealloc, Tree, gf_freeTree, "freeTree")
+/* PGF methods, constructor and destructor */
+DEALLOCFN(PGF_dealloc, PGFModule, gf_freePGF, "freePGF")
static gfType*
startCategory(PyObject *self, PyObject *noarg)
@@ -135,6 +107,7 @@ parse(PyObject *self, PyObject *args, PyObject *kws)
expr = (Tree*)TreeType.tp_new(&TreeType,NULL,NULL); // Expr* -> Tree*
expr->obj = *(p++);
PyList_Append(parsed, (PyObject*)expr);
+ Py_DECREF(expr); //??
/* char *str = gf_showExpr(exp);
puts(str);
free(str); */
@@ -143,15 +116,73 @@ parse(PyObject *self, PyObject *args, PyObject *kws)
return parsed;
}
-static PyObject*
-expr_repr(Expr *self)
+static PGFModule*
+readPGF(PyObject *self, PyObject *args)
+{
+ char *path;
+ PGFModule *pgf;
+ if (!PyArg_ParseTuple(args, "s", &path))
+ return NULL;
+ pgf = (PGFModule*)PGFType.tp_new(&PGFType,NULL,NULL);
+ if (!pgf) return NULL;
+ pgf->obj = gf_readPGF(path);
+ return pgf;
+}
+
+//Todo: repr
+
+static PyMethodDef pgf_methods[] = {
+ {"parse", (PyCFunction)parse, METH_VARARGS|METH_KEYWORDS,"Parse a string."},
+ {"startcat", (PyCFunction)startCategory, METH_NOARGS,"Get the start category."},
+ {NULL, NULL, 0, NULL} /* Sentinel */
+};
+
+
+
+
+/* Language methods, constructor and destructor */
+
+REPRCB(lang_repr, Lang, gf_showLanguage)
+DEALLOCFN(Lang_dealloc, Lang, gf_freeLanguage, "freeLanguage")
+
+static Lang*
+readLang(PyObject *self, PyObject *args)
{
- const char *str = gf_showExpr(self->obj);
- return PyString_FromString(str);
+ char *langName;
+ Lang *l;
+ if (!PyArg_ParseTuple(args,"s",&langName))
+ return NULL;
+ l = (Lang*)LangType.tp_new(&LangType,NULL,NULL);
+ if(!l) return NULL;
+ l->obj = gf_readLanguage(langName);
+ return l;
}
-
+
+/* gf types: methods, constructor and destructor */
+
+DEALLOCFN(gfType_dealloc, gfType, gf_freeType, "freeType")
+REPRCB(gfType_repr, gfType, gf_showType)
+
+
+
+
+/* expression type: methods, destructor */
+
+DEALLOCFN(expr_dealloc, Expr, gf_freeExpr, "freeExpr")
+REPRCB(expr_repr, Expr, gf_showExpr)
+
+
+/* tree typr: methods, constructor and destructor */
+// Are Expr and Tree equivalent ?
+
+REPRCB(tree_repr, Tree, gf_showExpr)
+DEALLOCFN(Tree_dealloc, Tree, gf_freeTree, "freeTree")
+
+
+/* gf module methods */
+
static PyMethodDef gf_methods[] = {
{"read_pgf", (PyCFunction)readPGF, METH_VARARGS,"Read pgf file."},
{"read_language", (PyCFunction)readLang, METH_VARARGS,"Get the language."},
@@ -159,12 +190,6 @@ static PyMethodDef gf_methods[] = {
{NULL, NULL, 0, NULL} /* Sentinel */
};
-static PyMethodDef pgf_methods[] = {
- {"parse", (PyCFunction)parse, METH_VARARGS|METH_KEYWORDS,"Parse a string."},
- {"startcat", (PyCFunction)startCategory, METH_NOARGS,"Get the start category."},
- {NULL, NULL, 0, NULL} /* Sentinel */
-};
-
#ifndef PyMODINIT_FUNC/* declarations for DLL import/export */
#define PyMODINIT_FUNC void
@@ -174,22 +199,17 @@ PyMODINIT_FUNC
initgf(void)
{
PyObject* m;
-#define READYTYPE(t) t.tp_new = PyType_GenericNew;\
+#define READYTYPE(t,trepr,tdealloc) t.tp_new = PyType_GenericNew; \
+ t.tp_repr = (reprfunc)trepr; \
+ t.tp_dealloc = (destructor)tdealloc; \
if (PyType_Ready(&t) < 0) return;
-
- PGFType.tp_repr = (reprfunc)PGF_repr;
+
PGFType.tp_methods = pgf_methods;
- PGFType.tp_dealloc = (destructor)PGF_dealloc;
- READYTYPE(PGFType)
- LangType.tp_dealloc = (destructor)Lang_dealloc;
- READYTYPE(LangType)
- gfTypeType.tp_dealloc = (destructor)gfType_dealloc;
- READYTYPE(gfTypeType)
- ExprType.tp_repr = (reprfunc)expr_repr;
- READYTYPE(ExprType)
- TreeType.tp_dealloc = (destructor)Tree_dealloc;
- // TreeType.tp_methods = tree_methods;
- READYTYPE(TreeType)
+ READYTYPE(PGFType,NULL,PGF_dealloc)
+ READYTYPE(LangType, lang_repr, Lang_dealloc)
+ READYTYPE(gfTypeType, gfType_repr, gfType_dealloc)
+ READYTYPE(ExprType, expr_repr, expr_dealloc)
+ READYTYPE(TreeType, tree_repr, Tree_dealloc)
m = Py_InitModule3("gf", gf_methods,
"Grammatical Framework.");
@@ -204,5 +224,6 @@ PyModule_AddObject(m, "gf", (PyObject *)&t);
ADDTYPE(PGFType)
ADDTYPE(LangType)
ADDTYPE(gfTypeType)
+ ADDTYPE(TreeType)
ADDTYPE(ExprType)
}