有人知道如何指示 SWIG 將 C 結(jié)構(gòu)的這些成員視為函數(shù)指針并使其可從 Python 調(diào)用嗎?完整的故事 我有包含指向函數(shù)的指針的 C 結(jié)構(gòu)。這些函數(shù)都是 typedefed。我有一個(gè) C 函數(shù),它將為此 C 結(jié)構(gòu)分配內(nèi)存,并將函數(shù)指針設(shè)置為指向有效的 C 函數(shù)。我的簡(jiǎn)化頭文件看起來像這樣// simplified api.htypedef void *handle_t;typedef void sample_t;typedef error_t comp_close_t(handle_t *h);typedef error_t comp_process_t(handle_t h, sample_t *in_ptr, sample_t *out_ptr, size_t *nr_samples);typedef struct{ comp_close_t *close; comp_process_t *process;} audio_comp_t;// prototype for initerror_t comp_init(handle_t *h, int size);以及相應(yīng)的簡(jiǎn)化源文件:// simplified api.cstatic comp_close_t my_close;static comp_process_t my_process;audio_comp_t comp = { my_close, my_process};error_t comp_init(audio_comp_t **handle) { *handle = ∁ return 0;}error_t my_close(handle_t *h) { // stuff *h = NULL; return 0;}error_t my_process(handle_t h, sample_t *in_ptr, sample_t *out_ptr, size_t *nr_samples) { audio_comp_t *c = (audio_comp_t*) h; // stuff printf("doing something useful\n");}以及我的界面文件的最新版本:%module comp_wrapper%{#include "api.h"%}%include "api.h"// Take care of the double pointer in comp_init%ignore comp_init;%rename(comp_init) comp_init_overload;%newobject comp_init;%inline %{audio_comp_t* comp_init_overload(int size) { audio_comp_t *result = NULL; error_t err = comp_init(&result, size); if (SSS_NO_ERROR == err) { ... } return result;}%}我可以通過類似“call_process”函數(shù)的方法來解決它,你可以在接口文件中找到它:call_process(h, in, out, 32) 但這需要我為所有 struct 成員函數(shù)添加一個(gè)額外的包裝器,而這不是必需的,因?yàn)?[SWIG 文檔指出完全支持函數(shù)指針][1]我假設(shè)我應(yīng)該在接口文件中編寫一些代碼,以便 SWIG 知道它正在處理一個(gè)函數(shù)而不是一個(gè) SwigPyObject
添加回答
舉報(bào)
0/150
提交
取消