Имам проблем с използването на Cython на конструктори по подразбиране.
Моят C++ клас Node е следният
Node.h
class Node
{
public:
Node()
{
std::cerr << "calling no arg constructor" << std::endl;
w=0.0;
d=0.0;
}
Node(double val, double val2);
{
std::cerr << "calling 2 args constructor" << std::endl;
this->w=val;
this->d=val2;
}
private:
double d,w;
}
е обвит в Cython, както следва
cdef extern from "Node.h":
cdef cppclass Node:
Node() except +
Node(double val1, double val2) except +
double d
double w
cdef class pyNode:
cdef Node *thisptr # hold a C++ instance which we're wrapping
def __cinit__(self):
self.thisptr = new Node()
def __cinit__(self, double val1, double val2):
self.thisptr = new Node(val1,val2)
def __dealloc__(self):
del self.thisptr
def __repr__(self):
return "d=%s w=%s" % (self.thisptr.w, self.thisptr.w )
Кодът на Cython се компилира добре, но особено когато се извиква от Python
from pyNode import pyNode as Node
n=Node(1.0,2.0)
Получавам очаквания низ calling 2 args constructor
, но ако се опитвам да декларирам обект Node от python с помощта на конструктора „без аргументи“ (който трябва да бъде правилно деклариран като __cinit__(self)
, не получавам резултат, това означава, че аргументът без аргумент конструктор не се извиква!
Как мога изрично да го извикам от метода cinit на обвития клас?