Index: swig/Lib/python/std_pair.i |
=================================================================== |
--- swig/Lib/python/std_pair.i (revision 0) |
+++ swig/Lib/python/std_pair.i (revision 0) |
@@ -0,0 +1,139 @@ |
+/* |
+ Pairs |
+*/ |
+%include <pystdcommon.swg> |
+ |
+//#define SWIG_STD_PAIR_ASVAL |
+ |
+%fragment("StdPairTraits","header",fragment="StdTraits") { |
+ namespace swig { |
+#ifdef SWIG_STD_PAIR_ASVAL |
+ template <class T, class U > |
+ struct traits_asval<std::pair<T,U> > { |
+ typedef std::pair<T,U> value_type; |
+ |
+ static int get_pair(PyObject* first, PyObject* second, |
+ std::pair<T,U> *val) |
+ { |
+ if (val) { |
+ T *pfirst = &(val->first); |
+ int res1 = swig::asval((PyObject*)first, pfirst); |
+ if (!SWIG_IsOK(res1)) return res1; |
+ U *psecond = &(val->second); |
+ int res2 = swig::asval((PyObject*)second, psecond); |
+ if (!SWIG_IsOK(res2)) return res2; |
+ return res1 > res2 ? res1 : res2; |
+ } else { |
+ T *pfirst = 0; |
+ int res1 = swig::asval((PyObject*)first, 0); |
+ if (!SWIG_IsOK(res1)) return res1; |
+ U *psecond = 0; |
+ int res2 = swig::asval((PyObject*)second, psecond); |
+ if (!SWIG_IsOK(res2)) return res2; |
+ return res1 > res2 ? res1 : res2; |
+ } |
+ } |
+ |
+ static int asval(PyObject *obj, std::pair<T,U> *val) { |
+ int res = SWIG_ERROR; |
+ if (PyTuple_Check(obj)) { |
+ if (PyTuple_GET_SIZE(obj) == 2) { |
+ res = get_pair(PyTuple_GET_ITEM(obj,0),PyTuple_GET_ITEM(obj,1), val); |
+ } |
+ } else if (PySequence_Check(obj)) { |
+ if (PySequence_Size(obj) == 2) { |
+ swig::SwigVar_PyObject first = PySequence_GetItem(obj,0); |
+ swig::SwigVar_PyObject second = PySequence_GetItem(obj,1); |
+ res = get_pair(first, second, val); |
+ } |
+ } else { |
+ value_type *p; |
+ res = SWIG_ConvertPtr(obj,(void**)&p,swig::type_info<value_type>(),0); |
+ if (SWIG_IsOK(res) && val) *val = *p; |
+ } |
+ return res; |
+ } |
+ }; |
+ |
+#else |
+ template <class T, class U > |
+ struct traits_asptr<std::pair<T,U> > { |
+ typedef std::pair<T,U> value_type; |
+ |
+ static int get_pair(PyObject* first, PyObject* second, |
+ std::pair<T,U> **val) |
+ { |
+ if (val) { |
+ value_type *vp = %new_instance(std::pair<T,U>); |
+ T *pfirst = &(vp->first); |
+ int res1 = swig::asval((PyObject*)first, pfirst); |
+ if (!SWIG_IsOK(res1)) return res1; |
+ U *psecond = &(vp->second); |
+ int res2 = swig::asval((PyObject*)second, psecond); |
+ if (!SWIG_IsOK(res2)) return res2; |
+ *val = vp; |
+ return SWIG_AddNewMask(res1 > res2 ? res1 : res2); |
+ } else { |
+ T *pfirst = 0; |
+ int res1 = swig::asval((PyObject*)first, pfirst); |
+ if (!SWIG_IsOK(res1)) return res1; |
+ U *psecond = 0; |
+ int res2 = swig::asval((PyObject*)second, psecond); |
+ if (!SWIG_IsOK(res2)) return res2; |
+ return res1 > res2 ? res1 : res2; |
+ } |
+ } |
+ |
+ static int asptr(PyObject *obj, std::pair<T,U> **val) { |
+ int res = SWIG_ERROR; |
+ if (PyTuple_Check(obj)) { |
+ if (PyTuple_GET_SIZE(obj) == 2) { |
+ res = get_pair(PyTuple_GET_ITEM(obj,0),PyTuple_GET_ITEM(obj,1), val); |
+ } |
+ } else if (PySequence_Check(obj)) { |
+ if (PySequence_Size(obj) == 2) { |
+ swig::SwigVar_PyObject first = PySequence_GetItem(obj,0); |
+ swig::SwigVar_PyObject second = PySequence_GetItem(obj,1); |
+ res = get_pair(first, second, val); |
+ } |
+ } else { |
+ value_type *p; |
+ res = SWIG_ConvertPtr(obj,(void**)&p,swig::type_info<value_type>(),0); |
+ if (SWIG_IsOK(res) && val) *val = p; |
+ } |
+ return res; |
+ } |
+ }; |
+ |
+#endif |
+ template <class T, class U > |
+ struct traits_from<std::pair<T,U> > { |
+ static PyObject *from(const std::pair<T,U>& val) { |
+ PyObject* obj = PyTuple_New(2); |
+ PyTuple_SetItem(obj,0,swig::from(val.first)); |
+ PyTuple_SetItem(obj,1,swig::from(val.second)); |
+ return obj; |
+ } |
+ }; |
+ } |
+} |
+ |
+%define %swig_pair_methods(pair...) |
+%extend { |
+%pythoncode {def __len__(self): return 2 |
+def __repr__(self): return str((self.first, self.second)) |
+def __getitem__(self, index): |
+ if not (index % 2): |
+ return self.first |
+ else: |
+ return self.second |
+def __setitem__(self, index, val): |
+ if not (index % 2): |
+ self.first = val |
+ else: |
+ self.second = val} |
+} |
+%enddef |
+ |
+%include <std/std_pair.i> |
+ |