[GNC-dev] Python-Bindings: issue when C expects GList argument
john
jralls at ceridwen.us
Tue May 10 11:25:33 EDT 2022
> On May 10, 2022, at 1:53 AM, Matteo Lasagni <laser820 at gmail.com> wrote:
>
> Thank you, John!
>
> I fixed it by adding the following into base-typemaps.i:
>
> %typemap(in) GList * {
> $1 = NULL;
> /* Check if is a list */
> if (PyList_Check($input)) {
> int i;
> int size = PyList_Size($input);
> for (i = size-1; i >= 0; i--) {
> PyObject *o = PyList_GetItem($input, i);
> $1 = g_list_prepend($1, o);
> }
> } else {
> PyErr_SetString(PyExc_TypeError, "not a list");
> return NULL;
> }
> }
>
> I had overlooked the swig definition in engine.i, where there is a typemap (in) for GList, but then it is cleared right afterwards...
> I am not (yet) very familiar with swig :-)
>
> I have also noticed that CreatePaymentLotSecs does not work out of the box, as it expects **Transaction while only *Transaction is type mapped.
>
> I will test these changes then I will figure out how to share them with the developers.
>
>
> Matteo
>
>
> On Tue, 10 May 2022 at 02:32, John Ralls <jralls at ceridwen.us <mailto:jralls at ceridwen.us>> wrote:
>
>
> > On May 9, 2022, at 2:17 PM, Matteo Lasagni <laser820 at gmail.com <mailto:laser820 at gmail.com>> wrote:
> >
> > Hi,
> > I am writing a python script to automatically associate a set of
> > invoices to a single transaction.
> > To this end, I am trying to use the function AutoApplyPaymentsWithLots
> > with no success:
> >
> >
> > lots = [lot1, lot2, lotn, ..]
> > owner.AutoApplyPaymentsWithLots(lots)
> >
> > This causes the following error:
> >
> > TypeError: in method 'gncOwnerAutoApplyPaymentsWithLots', argument 2 of
> > type 'GList *'
> >
> > I have tried different solutions from passing different types of python
> > objects, to updating the swig typemap and also to modifying the
> > auto-generated gnucash_core.c...nothing worked out so far.
> > I could write an additional c-wrapper, but I am sure there is a more
> > general solution.
>
> The fundamental problem is that there's only a Python out typemap for GList, that is one that converts from a GList* to a python list. Lacking an in typemap the gncOwner.AutoApplyPaymentsWithLots python wrapper expects an already constructed and Swig-wrapped GList*.
>
> Regards,
> John Ralls
>
>
Nice. Would you put that in a pull request?
There are two typemap(in) GList* in engine.i, but they're both for Guile (Scheme), not Python. 'scm' is the giveaway.
If there's a way to implement an output pointer parameter in Python I don't know about it. You can pass in a container object and put the output Transaction* in the container, but that's both a bit of a hack and doesn't have the same meaning as Transaction** nor is it very pythonic. Nor, for that matter, is gncOwnerCreatePaymentLotSecs a very good design as it mixes responsibilities. Unfortunately there's a lot of that in GnuCash because most of it is written with a very narrow focus, in this case providing for the payments dialog.
Regards,
John Ralls
More information about the gnucash-devel
mailing list