From 31db18046e38641558e21e3f68ca96ae0d02966b Mon Sep 17 00:00:00 2001 From: Adam Tkac Date: Wed, 16 Feb 2011 13:18:38 +0100 Subject: [PATCH] Improve fix for PySlice issue (#666429). Signed-off-by: Adam Tkac --- swig.spec | 5 +++- swig200-rh666429.patch | 60 +++++++++++++++++++++++++++++------------- 2 files changed, 45 insertions(+), 20 deletions(-) diff --git a/swig.spec b/swig.spec index 3b56648..a2633cc 100644 --- a/swig.spec +++ b/swig.spec @@ -4,7 +4,7 @@ Summary: Connects C/C++/Objective C to some high-level programming languages Name: swig Version: 2.0.1 -Release: 3%{?dist} +Release: 4%{?dist} License: GPLv3+ and BSD Group: Development/Tools URL: http://swig.sourceforge.net/ @@ -117,6 +117,9 @@ rm -rf %{buildroot} %doc Doc Examples LICENSE LICENSE-GPL LICENSE-UNIVERSITIES COPYRIGHT %changelog +* Wed Feb 16 2011 Adam Tkac 2.0.1-4 +- improve fix for PySlice issue (#666429) + * Wed Feb 09 2011 Fedora Release Engineering - 2.0.1-3 - Rebuilt for https://fedoraproject.org/wiki/Fedora_15_Mass_Rebuild diff --git a/swig200-rh666429.patch b/swig200-rh666429.patch index 8f2f12f..31dbe7f 100644 --- a/swig200-rh666429.patch +++ b/swig200-rh666429.patch @@ -1,45 +1,67 @@ diff -up swig-2.0.1/Lib/python/pycontainer.swg.rh666429 swig-2.0.1/Lib/python/pycontainer.swg ---- swig-2.0.1/Lib/python/pycontainer.swg.rh666429 2010-02-28 00:26:02.000000000 +0100 -+++ swig-2.0.1/Lib/python/pycontainer.swg 2011-01-03 13:02:29.303515695 +0100 -@@ -631,14 +631,6 @@ namespace swig +--- swig-2.0.1/Lib/python/pycontainer.swg.rh666429 2011-02-16 12:25:19.277091696 +0100 ++++ swig-2.0.1/Lib/python/pycontainer.swg 2011-02-16 12:48:43.273926091 +0100 +@@ -631,6 +631,7 @@ namespace swig return x; } -- /* typemap for slice object support */ -- %typemap(in) PySliceObject* { -- $1 = (PySliceObject *) $input; -- } -- %typemap(typecheck,precedence=SWIG_TYPECHECK_POINTER) PySliceObject* { -- $1 = PySlice_Check($input); -- } -- ++#if !NO_PYSLICE + /* typemap for slice object support */ + %typemap(in) PySliceObject* { + $1 = (PySliceObject *) $input; +@@ -638,6 +639,7 @@ namespace swig + %typemap(typecheck,precedence=SWIG_TYPECHECK_POINTER) PySliceObject* { + $1 = PySlice_Check($input); + } ++#endif + Sequence* __getslice__(difference_type i, difference_type j) throw (std::out_of_range) { return swig::getslice(self, i, j); - } -@@ -660,7 +652,7 @@ namespace swig +@@ -660,7 +662,11 @@ namespace swig /* Overloaded methods for Python 3 compatibility * (Also useful in Python 2.x) */ -- Sequence* __getitem__(PySliceObject *slice) throw (std::out_of_range) { ++#if NO_PYSLICE + Sequence* __getitem__(PyObject *slice) throw (std::out_of_range) { ++#else + Sequence* __getitem__(PySliceObject *slice) throw (std::out_of_range) { ++#endif Py_ssize_t i, j, step; if( !PySlice_Check(slice) ) { SWIG_Error(SWIG_TypeError, "Slice object expected."); -@@ -670,7 +662,7 @@ namespace swig +@@ -669,8 +675,11 @@ namespace swig + PySlice_GetIndices(slice, self->size(), &i, &j, &step); return swig::getslice(self, i, j); } - -- void __setitem__(PySliceObject *slice, const Sequence& v) +- ++#if NO_PYSLICE + void __setitem__(PyObject *slice, const Sequence& v) ++#else + void __setitem__(PySliceObject *slice, const Sequence& v) ++#endif throw (std::out_of_range, std::invalid_argument) { Py_ssize_t i, j, step; if( !PySlice_Check(slice) ) { -@@ -681,7 +673,7 @@ namespace swig +@@ -681,7 +690,11 @@ namespace swig swig::setslice(self, i, j, v); } -- void __delitem__(PySliceObject *slice) ++#if NO_PYSLICE + void __delitem__(PyObject *slice) ++#else + void __delitem__(PySliceObject *slice) ++#endif throw (std::out_of_range) { Py_ssize_t i, j, step; if( !PySlice_Check(slice) ) { +diff -up swig-2.0.1/Source/Modules/python.cxx.rh666429 swig-2.0.1/Source/Modules/python.cxx +--- swig-2.0.1/Source/Modules/python.cxx.rh666429 2011-02-16 12:20:37.557740471 +0100 ++++ swig-2.0.1/Source/Modules/python.cxx 2011-02-16 12:46:29.034224445 +0100 +@@ -440,6 +440,7 @@ public: + if (py3) { + /* force disable features that not compatible with Python 3.x */ + classic = 0; ++ Preprocessor_define((DOH *) "NO_PYSLICE 1", 0); + } + + if (cppcast) {