aboutsummaryrefslogtreecommitdiffstats
path: root/libpyside
diff options
context:
space:
mode:
authorHugo Parente Lima <hugo.pl@gmail.com>2010-09-02 20:33:00 -0300
committerHugo Parente Lima <hugo.pl@gmail.com>2010-09-03 10:59:43 -0300
commit823eec81c245f56cd2baf7c9fe0b1bf006500561 (patch)
tree9f9577ee6252f6d9cce086cffb20f2ff86ef3d12 /libpyside
parentf024b0d8840b00da4f3a703db5b22c70cf8b26ee (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.h17
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));
}
};