diff options
author | Hugo Parente Lima <hugo.pl@gmail.com> | 2010-09-02 20:33:00 -0300 |
---|---|---|
committer | Hugo Parente Lima <hugo.pl@gmail.com> | 2010-09-03 10:59:43 -0300 |
commit | 823eec81c245f56cd2baf7c9fe0b1bf006500561 (patch) | |
tree | 9f9577ee6252f6d9cce086cffb20f2ff86ef3d12 /libpyside | |
parent | f024b0d8840b00da4f3a703db5b22c70cf8b26ee (diff) |
Fix bug#320 - "OR'ing Qt alignments doesn't work; adding them does"
Reviewer: Luciano Wolf <luciano.wolf@openbossa.org>
Renato Araújo <renato.filho@openbossa.org>
Diffstat (limited to 'libpyside')
-rw-r--r-- | libpyside/pysideconversions.h | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/libpyside/pysideconversions.h b/libpyside/pysideconversions.h index c7fdcb516..35fa687df 100644 --- a/libpyside/pysideconversions.h +++ b/libpyside/pysideconversions.h @@ -237,19 +237,24 @@ struct QFlagsConverter || PyObject_TypeCheck(pyObj, Shiboken::SbkType<typename T::enum_type>()); } - static inline PyObject* toPython(void* cppobj) + static inline PyObject* toPython(void* cppObj) { - return toPython(*reinterpret_cast<T*>(cppobj)); + return toPython(*reinterpret_cast<T*>(cppObj)); } - static inline PyObject* toPython(T cppenum) + static inline PyObject* toPython(const T& cppObj) { - return Shiboken::SbkEnumObject_New(Shiboken::SbkType<T>(), (long) cppenum); + PyObject* qflags = Shiboken::SbkType<T>()->tp_alloc(Shiboken::SbkType<T>(), 0); + reinterpret_cast<PyIntObject*>(qflags)->ob_ival = cppObj; + return qflags; } - static inline T toCpp(PyObject* pyobj) + static inline T toCpp(PyObject* pyObj) { - return T(QFlag(reinterpret_cast<Shiboken::SbkEnumObject*>(pyobj)->ob_ival)); + if (Shiboken::isShibokenEnum(pyObj)) + return T(QFlag(reinterpret_cast<Shiboken::SbkEnumObject*>(pyObj)->ob_ival)); + else + return T(QFlag(reinterpret_cast<PyIntObject*>(pyObj)->ob_ival)); } }; |