2010-12-28 8 views
2

私はchar配列のCTypesポインタを返す必要があるPython C Extensionを書いています(私はCTypesポインタを必要とする別のPythonライブラリとのインタフェースが必要です)。CからのCTypesポインタの返却

CのCTypesインターフェイスのドキュメントは見つかりません。Pythonポインタコンストラクタの呼び出しなどの回避策はありますか?

static PyObject *get_pointer(myObject *self) 
{ 
    char *my_pointer = self->internal_pointer; 
    return PyCTypes_Pointer(my_pointer); /* how do I turn 'my_pointer' into 
       a Python object representing a CTypes pointer? */ 
} 

ありがとうございます。

+0

何か不足していますか?あなたは質問していません:http://docs.python.org/library/ctypes.html#ctypes-pointers – mjhm

+0

これはPythonコードです。私はCからポインタを構築する必要があります。 –

+0

あなたはSWIGを使いたいですか?それはとても強力です~~~ – kaitian521

答えて

0

Cでプログラミングしていても、Python自体を使ってみてください。残念ながら私はCのCTypesインターフェイスについて知らず、ソースでヒントを見つけることができませんでした。たぶんあなたはPyCTypes_Pointerメソッドを次のように書くことができます。

ここでは、クリーンアップ、エラーチェック、または処理は行っていませんが、Python 2.7および3.4​​で動作しています。ちょうどあなたが唯一のゼロ終端文字列を処理している場合、あなたは多分、直接ctypes.c_char_pを使用することができるかもしれません

from __future__ import print_function 
from distutils.core import Extension, setup 
import sys 
sys.argv.extend(["build_ext", "-i"]) 
setup(ext_modules = [Extension('pyp', ['pyp.c'])]) 
import pyp 
c = pyp.char_p() 
print(c[:pyp.len()]) 

を構築し、

<class 'ctypes.LP_c_char'> Testing Python ctypes char pointer ... 

のような出力を得る

#include <Python.h> 

static const char *test = "Testing Python ctypes char pointer ..."; 

static PyObject *c_char_p = NULL; 
static PyObject *c_void_p = NULL; 
static PyObject *cast = NULL; 

static PyObject * char_p (void) { 
    PyObject *p = PyLong_FromVoidPtr((void *) test); 
    p = PyObject_CallFunction(c_void_p, "O", p); 
    return PyObject_CallFunction(cast, "OO", p, c_char_p); 
} 

static PyObject *len (void) { 
    return PyLong_FromSize_t(strlen(test)); 
} 

static PyMethodDef methods[] = { 
    {"char_p", (PyCFunction) char_p, METH_NOARGS, ""}, 
    {"len", (PyCFunction) len, METH_NOARGS, ""}, 
    { NULL } 
}; 

#if PY_MAJOR_VERSION >= 3 
static PyModuleDef module = {PyModuleDef_HEAD_INIT, "pyt", "", -1, methods, 
    NULL, NULL, NULL, NULL}; 
#define INIT_FUNC PyInit_pyp 
#else 
#define INIT_FUNC initpyp 
#endif 

PyMODINIT_FUNC INIT_FUNC (void) { 
    PyObject* m; 

    PyObject *ctypes = PyImport_ImportModule("ctypes"); 
    PyObject *c_char = PyObject_GetAttrString(ctypes, "c_char"); 
    c_char_p = PyObject_CallMethod(ctypes, "POINTER", "O", c_char); 
    c_void_p = PyObject_GetAttrString(ctypes, "c_void_p"); 
    cast = PyObject_GetAttrString(ctypes, "cast"); 

#if PY_MAJOR_VERSION >= 3 
    m = PyModule_Create(&module); 
#else 
    m = Py_InitModule("pyp", methods); 
#endif 

    return (PyMODINIT_FUNC) m; 
} 

...

関連する問題