Your Boost.Python usage is fine. It's the Python code that inherently
won't work:
>> from MyModule import *
>> mc = MyClass()
>> p = []
>> mc.myFuncSet(p)
Here, 'p' doesn't actually have a std::vector in it - it's a regular
Python list, so Boost.Python can't get a std::vector reference out of it.
Instead you can do:
>> from MyModule import *
>> mc = MyClass()
>> p = MyList()
>> mc.myFuncSet(p)
One could imagine writing a fancy converter that would allow the first
form by making a temporary std::vector, passing that to the C++
function, and then copying the elements in the vector back into the
Python list. But that's potentially a very expensive sequence of
operations, and it's actually impossible to do that through a registered
converter in Boost.Python. If you really want that Python syntax to
work, you'll have to write a C++ function that takes a
boost::python::list argument and calls the actual C++ function that
operates on std::vector.
Jim
On 01/21/2012 11:40 AM, DeVico, Mike wrote:
Hello,
I would like to wrap a class that looks like below (taken from an
example I found on another site)
#include
#include
#include
typedef std::vector MyList;
class MyClass {
public:
MyList myFuncGet()
{
return MyList();
}
void myFuncSet(MyList& list)
{
list.push_back("Hello");
}
// stuff
};
BOOST_PYTHON_MODULE(MyModule)
{
class_("MyList")
.def(vector_indexing_suite() );
class_("MyClass")
.def("myFuncGet", &MyClass::myFuncGet)
.def("myFuncSet", &MyClass::myFuncSet)
;
}
However, this is what I get when I try to use it from python:
Python 2.7.2 (default, Jun 12 2011, 14:24:46) [MSC v.1500 64 bit
(AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>> from MyModule import *
>> mc = MyClass()
>> p = []
>> mc.myFuncSet(p)
Traceback (most recent call last):
File "", line 1, in
Boost.Python.ArgumentError: Python argument types in
MyClass.myFuncSet(MyClass, list)
did not match C++ signature:
myFuncSet(MyClass {lvalue}, std::vector > {lvalue})
>>
I know I’m missing a converter function, but I’m new to boost and I
don’t know what the converter
should look like in this case.
I’ve found lots of working examples of how to return a vector, but I
want to be able to pass the vector
into the function by reference and modify it.
I would really appreciate it if someone could complete the example by
adding the necessary converter
code.
Thanks in advance.
--Mike
___
Cplusplus-sig mailing list
Cplusplus-sig@python.org
http://mail.python.org/mailman/listinfo/cplusplus-sig
___
Cplusplus-sig mailing list
Cplusplus-sig@python.org
http://mail.python.org/mailman/listinfo/cplusplus-sig