/* NOTE: you have two options when adding classes so that they are callable *from* python. - either you %include the header file - or you re-declare it In both cases, you must #include the required header file (i.e. the header file itself), otherwise enigma_python_wrap.cxx won't build. In case you import the whole header file, please make sure that no unimportant stuff is wrapped, as this makes the wrapper stuff much more complex and it can probably break very easily because of missing typemaps etc. you could make use of dizzy macros to ensure that some stuff is left out when parsed as SWIG definitions, but be sure to not modify the binary representation. DON'T USE #ifdef SWIG_COMPILE for leaving out stuff (unless you *really* know what you are doing,of course!). you WILL break it. The better way (with more work) is to re-declare the class. It won't be compiled, so you can leave out stuff as you like. Oh, things like "operator= is private in this context" etc. is usually caused by not marking PSignals as immutable. */ %module enigma %{ #define SWIG_COMPILE #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include %} %feature("ref") iObject "$this->AddRef(); /* eDebug(\"AddRef (%s:%d)!\", __FILE__, __LINE__); */ " %feature("unref") iObject "$this->Release(); /* eDebug(\"Release! %s:%d\", __FILE__, __LINE__); */ " /* this magic allows smartpointer to be used as OUTPUT arguments, i.e. call-by-reference-styled return value. */ %define %typemap_output_simple(Type) %typemap(in,numinputs=0) Type *OUTPUT ($*1_ltype temp), Type &OUTPUT ($*1_ltype temp) "$1 = new Type;"; %fragment("t_out_helper"{Type},"header", fragment="t_output_helper") {} %typemap(argout,fragment="t_out_helper"{Type}) Type *OUTPUT, Type &OUTPUT "$result = t_output_helper($result, (SWIG_NewPointerObj((void*)($1), $1_descriptor, 1)));" %enddef %define %typemap_output_ptr(Type) %typemap(in,numinputs=0) Type *OUTPUT ($*1_ltype temp), Type &OUTPUT ($*1_ltype temp) "$1 = new Type;"; %fragment("t_out_helper"{Type},"header", fragment="t_output_helper") {} %typemap(argout,fragment="t_out_helper"{Type}) Type *OUTPUT, Type &OUTPUT // generate None if smartpointer is NULL "$result = t_output_helper($result, ((*$1) ? SWIG_NewPointerObj((void*)($1), $1_descriptor, 1) : (delete $1, Py_INCREF(Py_None), Py_None)));" %enddef #define DEBUG typedef long time_t; %include "typemaps.i" %include "std_string.i" %include %include %include %immutable eSocketNotifier::activated; %include %include %include %include %include // TODO: embed these... %immutable ePicLoad::PictureData; %immutable eButton::selected; %immutable eInput::changed; %immutable eComponentScan::statusChanged; %immutable eComponentScan::newService; %immutable pNavigation::m_event; %immutable pNavigation::m_record_event; %immutable eListbox::selectionChanged; %immutable eDVBCI_UI::ciStateChanged; %immutable eSocket_UI::socketStateChanged; %immutable eDVBResourceManager::frontendUseMaskChanged; %immutable eAVSwitch::vcr_sb_notifier; %immutable ePythonMessagePump::recv_msg; %immutable eDVBLocalTimeHandler::m_timeUpdated; %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include %include /************** eptr **************/ /************** signals **************/ template class PSignal0 { public: PyObject *get(); }; %template(PSignal0V) PSignal0; %typemap(out) PSignal0V { $1 = $input->get(); } template class PSignal1 { public: PyObject *get(); }; %template(PSignal1VI) PSignal1; %template(PSignal1VS) PSignal1; %typemap(out) PSignal1VI { $1 = $input->get(); } %typemap(out) PSignal1VS { $1 = $input->get(); } template class PSignal2 { public: PyObject *get(); }; %template(PSignal2VoidIRecordableServiceInt) PSignal2&,int>; %typemap(out) PSignal2VoidIRecordableServiceInt { $1 = $input->get(); } %{ RESULT SwigFromPython(ePtr &result, PyObject *obj) { ePtr *res; res = 0; result = 0; #ifndef SWIGTYPE_p_ePtrT_gPixmap_t #define SWIGTYPE_p_ePtrT_gPixmap_t SWIGTYPE_p_ePtrTgPixmap_t #endif if (SWIG_Python_ConvertPtr(obj, (void **)&res, SWIGTYPE_p_ePtrT_gPixmap_t, SWIG_POINTER_EXCEPTION | 0)) return -1; if (!res) return -1; result = *res; return 0; } PyObject *New_eServiceReference(const eServiceReference &ref) { eServiceReference *result = new eServiceReference(ref); return SWIG_NewPointerObj((void*)(result), SWIGTYPE_p_eServiceReference, 1); } PyObject *New_iRecordableServicePtr(const ePtr &ptr) { ePtr *result = new ePtr(ptr); #ifndef SWIGTYPE_p_ePtrT_iRecordableService_t #define SWIGTYPE_p_ePtrT_iRecordableService_t SWIGTYPE_p_ePtrTiRecordableService_t #endif return SWIG_NewPointerObj((void*)(result), SWIGTYPE_p_ePtrT_iRecordableService_t, 1); } %} /* needed for service groups */ PyObject *getBestPlayableServiceReference(const eServiceReference &bouquet_ref, const eServiceReference &ignore, bool simulate=false); %{ PyObject *getBestPlayableServiceReference(const eServiceReference &bouquet_ref, const eServiceReference &ignore, bool simulate=false) { eStaticServiceDVBBouquetInformation info; if (info.isPlayable(bouquet_ref, ignore, simulate)) return New_eServiceReference(info.getPlayableService()); Py_INCREF(Py_None); return Py_None; } %} void setTunerTypePriorityOrder(int); %{ void setTunerTypePriorityOrder(int order) { eDVBFrontend::setTypePriorityOrder(order); } %} /************** temp *****************/ /* need a better place for this, i agree. */ %{ extern void runMainloop(); extern void quitMainloop(int exit_code); extern eApplication *getApplication(); extern int getPrevAsciiCode(); extern void addFont(const char *filename, const char *alias, int scale_factor, int is_replacement); extern const char *getEnigmaVersionString(); extern void dump_malloc_stats(void); %} extern void addFont(const char *filename, const char *alias, int scale_factor, int is_replacement); extern int getPrevAsciiCode(); extern void runMainloop(); extern void quitMainloop(int exit_code); extern eApplication *getApplication(); extern const char *getEnigmaVersionString(); extern void dump_malloc_stats(void);