Обертка Swig для функции с другим указателем структуры - PullRequest
0 голосов
/ 07 февраля 2019

Я хочу обернуть следующую функцию C.Обратите внимание, что приведение типов из Foo_t * в Bar_t *:

void function(Foo_t * f) {
      Bar_t * b = (Bar_t *) f;  // casting is done in C original code
      //do sth with b
}

Swig генерирует оболочку, которая соответствует следующему шаблону:

void wrap_function( Foo_t *foo ) {
     function(foo);
}

Но в Python я хочу вызвать свою функцию оболочкис использованием экземпляра Bar_t:

b = Bar_t()
function(b) 

Итак, я запустил следующую карту типов:

%typemap(in) Foo * {
  Bar_t *temp;
  int res0 = 0;
  Foo_t *arg = 0;

  res0 = SWIG_ConvertPtr($input, (void **) &temp, $descriptor(Bar_t *), 0|0);
    if (!SWIG_IsOK(res0)) {
        SWIG_exception_fail(SWIG_ArgError(res0), "in method '" "function" "', argument " "1"" of type '" "Bar_t *""'"); 
    } 
     $1 = (Foo_t *) temp;
     function(arg);
}

Но исключение выдается!

Как я могу привести изОт Bar_t * до Foo_t *?

1 Ответ

0 голосов
/ 09 февраля 2019

Если вы создадите карту типов для ожидания обертки Python Bar_t для ввода Foo *, вы не сможете передать Foo * на вход Foo *.Вместо этого экспортируйте помощник приведения.Обратите внимание, что запись %inline реализует и экспортирует оболочку для содержимого.

test.h

#ifdef _WIN32
#   ifdef EXPORT
#       define API __declspec(dllexport)
#   else
#       define API __declspec(dllimport)
#   endif
#else
#   define API
#endif

typedef struct Foo {
    int a;
} Foo_t;

typedef struct Bar {
    int b;
} Bar_t;

API void function(Foo_t * f);

test.c

#define EXPORT
#include <stdio.h>
#include "test.h"

API void function(Foo_t * f) {
      Bar_t * b = (Bar_t *) f;  // casting is done in C original code
      // do something with b
}

test.i

%module test

%{
#include "test.h"
%}

%inline %{
Foo_t* Foo_cast(Bar_t* bar) {
    return (Foo_t*)bar;
}
%}

%include "test.h"

Тестирование:

>>> import test
>>> bar = test.Bar_t()
>>> test.function(test.Foo_cast(bar))
>>> foo = test.Foo_t()
>>> test.function(foo)
>>>
...