1
0
forked from GitHub/gf-core

Started adding support for 'with' construct, failing tests commented out

This commit is contained in:
John J. Camilleri
2021-09-21 17:23:38 +02:00
parent 6edf7e6405
commit 71dac482c8
2 changed files with 64 additions and 7 deletions

View File

@@ -16,6 +16,13 @@ def gr2(gr1):
assert t.commit()
return gr1
@pytest.fixture(scope="module")
def gr3(gr1):
with gr1.newTransaction() as t:
t.createFunction("bar", ty, 0, prob),
# t.createCategory("R", [(BIND_TYPE_EXPLICIT, "x", ty)], prob)
return gr1
# gr1
def test_original_functions(gr1):
@@ -48,3 +55,11 @@ def test_extended_function_type(gr2):
# def test_extended_function_prob(gr2):
# assert gr2.functionProbability("foo") == prob
# gr3
# def test_branched_functions(gr3):
# assert gr3.functions == ["bar", "c", "ind", "s", "z"]
#
# def test_branched_function_type(gr3):
# assert gr3.functionType("bar") == ty

View File

@@ -1,6 +1,6 @@
#define PY_SSIZE_T_CLEAN
#include <Python.h>
// #include <stdbool.h>
#include <structmember.h>
#include <pgf/pgf.h>
#include "./expr.h"
@@ -137,6 +137,40 @@ Transaction_dropCategory(TransactionObject *self, PyObject *args)
// ----------------------------------------------------------------------------
static PyObject *
Transaction_enter(TransactionObject *self, PyObject *Py_UNUSED(ignored))
{
Py_RETURN_TRUE;
}
static PyObject *
Transaction_exit(TransactionObject *self, PyObject *const *args, Py_ssize_t nargs)
{
// PyObject *exc_type = Py_None;
// PyObject *exc_value = Py_None;
// PyObject *exc_tb = Py_None;
// if (!_PyArg_CheckPositional("__exit__", nargs, 0, 3)) {
// Py_RETURN_FALSE;
// }
if (nargs < 1) {
goto skip_optional;
}
// exc_type = args[0];
// if (nargs < 2) {
// goto skip_optional;
// }
// exc_value = args[1];
// if (nargs < 3) {
// goto skip_optional;
// }
// exc_tb = args[2];
skip_optional:
// TODO check exception
return Transaction_commit(self, NULL);
}
// static void
// Transaction_dealloc(PGFObject* self)
// {
@@ -147,15 +181,23 @@ static PyGetSetDef Transaction_getseters[] = {
{NULL} /* Sentinel */
};
// static PyMemberDef Transaction_members[] = {
// {NULL} /* Sentinel */
// };
static PyMemberDef Transaction_members[] = {
{NULL} /* Sentinel */
};
static PyMethodDef Transaction_methods[] = {
{"commit", (PyCFunction)Transaction_commit, METH_VARARGS,
"Commit transaction"
},
{"__enter__", (PyCFunction)Transaction_enter, METH_NOARGS,
""
},
{"__exit__", (PyCFunction)(void(*)(void))Transaction_exit, METH_FASTCALL,
""
},
{"createFunction", (PyCFunction)Transaction_createFunction, METH_VARARGS,
"Create function"
},
@@ -175,7 +217,7 @@ PyTypeObject pgf_TransactionType = {
PyVarObject_HEAD_INIT(NULL, 0)
//0, /*ob_size*/
"pgf.Transaction", /*tp_name*/
sizeof(PGFObject), /*tp_basicsize*/
sizeof(TransactionObject), /*tp_basicsize*/
0, /*tp_itemsize*/
0, //(destructor)Transaction_dealloc, /*tp_dealloc*/
0, /*tp_print*/
@@ -193,7 +235,7 @@ PyTypeObject pgf_TransactionType = {
0, /*tp_setattro*/
0, /*tp_as_buffer*/
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /*tp_flags*/
"PGF transaction", /*tp_doc*/
"Transaction object", /*tp_doc*/
0, /*tp_traverse */
0, /*tp_clear */
0, /*tp_richcompare */
@@ -201,7 +243,7 @@ PyTypeObject pgf_TransactionType = {
0, /*tp_iter */
0, /*tp_iternext */
Transaction_methods, /*tp_methods */
0, //Transaction_members, /*tp_members */
Transaction_members, /*tp_members */
Transaction_getseters, /*tp_getset */
0, /*tp_base */
0, /*tp_dict */