forked from pool/python-wxPython
Accepting request 995040 from X11:wxWidgets
OBS-URL: https://build.opensuse.org/request/show/995040 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-wxPython?expand=0&rev=14
This commit is contained in:
commit
854eb87f77
26
0001-Check-HSV-values-in-image-test.patch
Normal file
26
0001-Check-HSV-values-in-image-test.patch
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
From 12cb5458cf5c26080158ecbee010ae9073a907e7 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Stefan=20Br=C3=BCns?= <stefan.bruens@rwth-aachen.de>
|
||||||
|
Date: Sun, 4 Oct 2020 21:19:36 +0200
|
||||||
|
Subject: [PATCH] Check HSV values in image test
|
||||||
|
|
||||||
|
---
|
||||||
|
unittests/test_image.py | 3 +++
|
||||||
|
1 file changed, 3 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/unittests/test_image.py b/unittests/test_image.py
|
||||||
|
index 767b36a7..a1dc0d7d 100644
|
||||||
|
--- a/unittests/test_image.py
|
||||||
|
+++ b/unittests/test_image.py
|
||||||
|
@@ -234,6 +234,9 @@ class image_Tests(wtc.WidgetTestCase):
|
||||||
|
rgb = wx.Image.RGBValue(1,2,3)
|
||||||
|
hsv = wx.Image.RGBtoHSV(rgb)
|
||||||
|
rgb = wx.Image.HSVtoRGB(hsv)
|
||||||
|
+ self.assertAlmostEqual(hsv.value * 255.0, 3.0)
|
||||||
|
+ self.assertAlmostEqual(hsv.saturation* 255.0, 170.0)
|
||||||
|
+ self.assertAlmostEqual(hsv.hue * 360.0, 210.0)
|
||||||
|
self.assertEqual(rgb.red, 1)
|
||||||
|
self.assertEqual(rgb.green, 2)
|
||||||
|
self.assertEqual(rgb.blue, 3)
|
||||||
|
--
|
||||||
|
2.28.0
|
||||||
|
|
31
0001-Fix-overflow-check-for-wxUIntPtr-type.patch
Normal file
31
0001-Fix-overflow-check-for-wxUIntPtr-type.patch
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
From c72d78fb983bf2efe4041f5d3c86670b92e98565 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Stefan=20Br=C3=BCns?= <stefan.bruens@rwth-aachen.de>
|
||||||
|
Date: Sun, 4 Oct 2020 23:02:19 +0200
|
||||||
|
Subject: [PATCH] Fix overflow check for wxUIntPtr type
|
||||||
|
|
||||||
|
long is 32bit on 32-bit archs and on Win64 (see
|
||||||
|
https://en.cppreference.com/w/cpp/language/types ). As SIP uses
|
||||||
|
PyLong_AsLongLong internally and uses an extra bounds check only if
|
||||||
|
explicitly enabled("sip.enableoverflowchecking(True)"), the overflow
|
||||||
|
only triggers when it also overflows `long long`, i.e. when
|
||||||
|
_LONG_MAX == _LLONG_MAX.
|
||||||
|
---
|
||||||
|
unittests/test_listctrl.py | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/unittests/test_listctrl.py b/unittests/test_listctrl.py
|
||||||
|
index c8c2d39a..0b2e3706 100644
|
||||||
|
--- a/unittests/test_listctrl.py
|
||||||
|
+++ b/unittests/test_listctrl.py
|
||||||
|
@@ -185,7 +185,7 @@ class listctrl_Tests(wtc.WidgetTestCase):
|
||||||
|
def test_listctrlItemData02(self):
|
||||||
|
lc = self._makeListCtrl()
|
||||||
|
with self.assertRaises(OverflowError):
|
||||||
|
- lc.SetItemData(0, wx._core._LONG_MAX + 100)
|
||||||
|
+ lc.SetItemData(0, wx._core._LLONG_MAX + 100)
|
||||||
|
|
||||||
|
|
||||||
|
def test_listctrlDeleteAllColumns(self):
|
||||||
|
--
|
||||||
|
2.28.0
|
||||||
|
|
36
0001-Only-import-attrdict-where-needed.patch
Normal file
36
0001-Only-import-attrdict-where-needed.patch
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
From 60a1917825044fc3a43dc39ef8de2b944150dc8a Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Stefan=20Br=C3=BCns?= <stefan.bruens@rwth-aachen.de>
|
||||||
|
Date: Sat, 25 Jun 2022 18:50:45 +0200
|
||||||
|
Subject: [PATCH 1/4] Only import attrdict where needed
|
||||||
|
|
||||||
|
Its only used for MSVC builds, but an unnecessary external dependency
|
||||||
|
elsewhere.
|
||||||
|
---
|
||||||
|
buildtools/config.py | 4 ++--
|
||||||
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/buildtools/config.py b/buildtools/config.py
|
||||||
|
index 4482ba9d..493a63c5 100644
|
||||||
|
--- a/buildtools/config.py
|
||||||
|
+++ b/buildtools/config.py
|
||||||
|
@@ -27,8 +27,6 @@ from distutils.dep_util import newer
|
||||||
|
|
||||||
|
import distutils.sysconfig
|
||||||
|
|
||||||
|
-from attrdict import AttrDict
|
||||||
|
-
|
||||||
|
runSilently = False
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
@@ -989,6 +987,8 @@ def getMSVCInfo(PYTHON, arch, set_env=False):
|
||||||
|
if MSVCinfo is not None:
|
||||||
|
return MSVCinfo
|
||||||
|
|
||||||
|
+ from attrdict import AttrDict
|
||||||
|
+
|
||||||
|
# Note that it starts with a monkey-patch in setuptools.msvc to
|
||||||
|
# workaround this issue: pypa/setuptools#1902
|
||||||
|
cmd = \
|
||||||
|
--
|
||||||
|
2.36.1
|
||||||
|
|
49
0003-Make-pip-usage-in-wxget-optional.patch
Normal file
49
0003-Make-pip-usage-in-wxget-optional.patch
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
From 00ba66a86f65abb24402427d66bf50e8da477321 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Stefan=20Br=C3=BCns?= <stefan.bruens@rwth-aachen.de>
|
||||||
|
Date: Tue, 28 Jun 2022 18:16:34 +0200
|
||||||
|
Subject: [PATCH 3/4] Make pip usage in wxget optional
|
||||||
|
|
||||||
|
As the code states, using pip to download is abusing it, and as it is
|
||||||
|
just a fallback in case neither wget nor urllib works.
|
||||||
|
---
|
||||||
|
wx/tools/wxget.py | 10 +++++++---
|
||||||
|
1 file changed, 7 insertions(+), 3 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/wx/tools/wxget.py b/wx/tools/wxget.py
|
||||||
|
index c83ced7a..75eb0f47 100644
|
||||||
|
--- a/wx/tools/wxget.py
|
||||||
|
+++ b/wx/tools/wxget.py
|
||||||
|
@@ -33,7 +33,6 @@ import os
|
||||||
|
import wx
|
||||||
|
import subprocess
|
||||||
|
import ssl
|
||||||
|
-import pip
|
||||||
|
|
||||||
|
if sys.version_info >= (3,):
|
||||||
|
from urllib.error import (HTTPError, URLError)
|
||||||
|
@@ -44,6 +43,11 @@ else:
|
||||||
|
from urllib2 import (HTTPError, URLError)
|
||||||
|
import urlparse
|
||||||
|
|
||||||
|
+try:
|
||||||
|
+ import pip
|
||||||
|
+except ImportError as e:
|
||||||
|
+ pip = None
|
||||||
|
+
|
||||||
|
def get_docs_demo_url(demo=False):
|
||||||
|
""" Get the URL for the docs or demo."""
|
||||||
|
if demo:
|
||||||
|
@@ -196,8 +200,8 @@ def download_file(url, dest=None, force=False, trusted=False):
|
||||||
|
success = download_wget(url, filename, trusted) # Try wget
|
||||||
|
if not success:
|
||||||
|
success = download_urllib(url, filename) # Try urllib
|
||||||
|
- if not success:
|
||||||
|
- success = download_pip(url, filename, force, trusted) # Try urllib
|
||||||
|
+ if not success and pip not None:
|
||||||
|
+ success = download_pip(url, filename, force, trusted) # Try pip
|
||||||
|
if not success:
|
||||||
|
split_url = url.split('/')
|
||||||
|
msg = '\n'.join([
|
||||||
|
--
|
||||||
|
2.36.1
|
||||||
|
|
@ -0,0 +1,55 @@
|
|||||||
|
From 70ecc1afcdd59bbd3b700d000e8f92740d218245 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?Stefan=20Br=C3=BCns?= <stefan.bruens@rwth-aachen.de>
|
||||||
|
Date: Tue, 28 Jun 2022 18:32:32 +0200
|
||||||
|
Subject: [PATCH 4/4] Fix time_t ETG typedef, extend DateTime.FromTimeT tests
|
||||||
|
|
||||||
|
Before c78823549bac ("Ensure time_t is treated as a 64-bit value by SIP")
|
||||||
|
the typedef used "long" instead of wxInt64, which caused issues on Win64,
|
||||||
|
as long is 32bit there (LLP64). On the other hand, wxInt64 is wrong on
|
||||||
|
32 bit Linux (e.g. armv7, i586), and thus the code crashes.
|
||||||
|
|
||||||
|
As SIP_SSIZE_T is 64 bit for both LLP64 (Windows) and LP64 (Linux), but
|
||||||
|
32 bit on 32bit archs, it matches time_t better (though, according to the
|
||||||
|
C standard, it could even be a double).
|
||||||
|
---
|
||||||
|
etg/defs.py | 2 +-
|
||||||
|
unittests/test_wxdatetime.py | 8 +++++++-
|
||||||
|
2 files changed, 8 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/etg/defs.py b/etg/defs.py
|
||||||
|
index 4445cf93..ceb9e2ef 100644
|
||||||
|
--- a/etg/defs.py
|
||||||
|
+++ b/etg/defs.py
|
||||||
|
@@ -73,7 +73,7 @@ def run():
|
||||||
|
td = module.find('wxUIntPtr')
|
||||||
|
module.insertItemAfter(td, etgtools.TypedefDef(type='wchar_t', name='wxUChar'))
|
||||||
|
module.insertItemAfter(td, etgtools.TypedefDef(type='wchar_t', name='wxChar'))
|
||||||
|
- module.insertItemAfter(td, etgtools.TypedefDef(type='wxInt64', name='time_t'))
|
||||||
|
+ module.insertItemAfter(td, etgtools.TypedefDef(type='long', name='time_t'))
|
||||||
|
module.insertItemAfter(td, etgtools.TypedefDef(type='long long', name='wxFileOffset'))
|
||||||
|
module.insertItemAfter(td, etgtools.TypedefDef(type='SIP_SSIZE_T', name='ssize_t'))
|
||||||
|
module.insertItemAfter(td, etgtools.TypedefDef(type='unsigned char', name='byte', pyInt=True))
|
||||||
|
diff --git a/unittests/test_wxdatetime.py b/unittests/test_wxdatetime.py
|
||||||
|
index 62e7d141..2f620045 100644
|
||||||
|
--- a/unittests/test_wxdatetime.py
|
||||||
|
+++ b/unittests/test_wxdatetime.py
|
||||||
|
@@ -25,9 +25,15 @@ class datetime_Tests(wtc.WidgetTestCase):
|
||||||
|
def test_datetime2(self):
|
||||||
|
d1 = wx.DateTime.FromHMS(8, 15, 45, 123)
|
||||||
|
d2 = wx.DateTime.FromJDN(12345.67)
|
||||||
|
- d3 = wx.DateTime.FromTimeT(int(time.time()))
|
||||||
|
d4 = wx.DateTime.FromDMY(1, wx.DateTime.Mar, 2012, 8, 15, 45, 123)
|
||||||
|
|
||||||
|
+ def test_datetimeTimeT(self):
|
||||||
|
+ d1 = wx.DateTime.FromTimeT(0)
|
||||||
|
+ self.assertEqual(d1.year, 1970)
|
||||||
|
+ d2 = wx.DateTime.FromTimeT(1643756400) # 2022-02-02
|
||||||
|
+ self.assertEqual(d2.year, 2022)
|
||||||
|
+ d3 = wx.DateTime.FromTimeT(int(time.time()))
|
||||||
|
+
|
||||||
|
def test_datetime3(self):
|
||||||
|
d1 = wx.DateTime.Today()
|
||||||
|
d2 = wx.DateTime.Now()
|
||||||
|
--
|
||||||
|
2.36.1
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
@ -1,7 +1,7 @@
|
|||||||
<multibuild>
|
<multibuild>
|
||||||
<package>python3</package>
|
<package>python3</package>
|
||||||
<package>python36</package>
|
|
||||||
<package>python38</package>
|
<package>python38</package>
|
||||||
<package>python39</package>
|
<package>python39</package>
|
||||||
<package>python310</package>
|
<package>python310</package>
|
||||||
|
<package>python311</package>
|
||||||
</multibuild>
|
</multibuild>
|
||||||
|
@ -1,83 +0,0 @@
|
|||||||
---
|
|
||||||
docker/build/ubuntu-18.04/Dockerfile | 4 +++-
|
|
||||||
docker/build/ubuntu-20.04/Dockerfile | 2 +-
|
|
||||||
wx/lib/agw/flatnotebook.py | 14 +++++++-------
|
|
||||||
wx/svg/__init__.py | 4 ++--
|
|
||||||
4 files changed, 13 insertions(+), 11 deletions(-)
|
|
||||||
|
|
||||||
--- a/docker/build/ubuntu-18.04/Dockerfile
|
|
||||||
+++ b/docker/build/ubuntu-18.04/Dockerfile
|
|
||||||
@@ -53,6 +53,7 @@ RUN \
|
|
||||||
apt-get install -y python3.7 python3.7-dev libpython3.7-dev python3.7-venv; \
|
|
||||||
apt-get install -y python3.8 python3.8-dev libpython3.8-dev python3.8-venv; \
|
|
||||||
apt-get install -y python3.9 python3.9-dev libpython3.9-dev python3.9-venv; \
|
|
||||||
+ apt-get install -y python3.10 python3.10-dev libpython3.10-dev python3.10-venv; \
|
|
||||||
apt-get clean;
|
|
||||||
|
|
||||||
# Add files from host into the container
|
|
||||||
@@ -72,7 +73,8 @@ RUN \
|
|
||||||
python3.6 -m venv venvs/Py36; \
|
|
||||||
python3.7 -m venv venvs/Py37; \
|
|
||||||
python3.8 -m venv venvs/Py38; \
|
|
||||||
- python3.9 -m venv venvs/Py39;
|
|
||||||
+ python3.9 -m venv venvs/Py39; \
|
|
||||||
+ python3.10 -m venv venvs/Py310;
|
|
||||||
|
|
||||||
# Define default command
|
|
||||||
CMD ["/bin/bash", "-l"]
|
|
||||||
--- a/docker/build/ubuntu-20.04/Dockerfile
|
|
||||||
+++ b/docker/build/ubuntu-20.04/Dockerfile
|
|
||||||
@@ -3,7 +3,7 @@ FROM ubuntu:20.04
|
|
||||||
|
|
||||||
# Set environment variables
|
|
||||||
ENV DIST_NAME=ubuntu-20.04
|
|
||||||
-ENV USE_DEADSNAKES=no
|
|
||||||
+ENV USE_DEADSNAKES=yes
|
|
||||||
ENV USER=wxpy
|
|
||||||
ENV HOME=/home/$USER
|
|
||||||
ENV PYTHONUNBUFFERED=1
|
|
||||||
--- a/wx/lib/agw/flatnotebook.py
|
|
||||||
+++ b/wx/lib/agw/flatnotebook.py
|
|
||||||
@@ -925,14 +925,14 @@ def DrawButton(dc, rect, focus, upperTab
|
|
||||||
|
|
||||||
if focus:
|
|
||||||
if upperTabs:
|
|
||||||
- leftPt = wx.Point(rect.x, rect.y + (rect.height / 10)*8)
|
|
||||||
- rightPt = wx.Point(rect.x + rect.width - 2, rect.y + (rect.height / 10)*8)
|
|
||||||
+ leftPt = wx.Point(rect.x, int(rect.y + (rect.height / 10)*8))
|
|
||||||
+ rightPt = wx.Point(rect.x + rect.width - 2, int(rect.y + (rect.height / 10)*8))
|
|
||||||
else:
|
|
||||||
- leftPt = wx.Point(rect.x, rect.y + (rect.height / 10)*5)
|
|
||||||
- rightPt = wx.Point(rect.x + rect.width - 2, rect.y + (rect.height / 10)*5)
|
|
||||||
+ leftPt = wx.Point(rect.x, int(rect.y + (rect.height / 10)*5))
|
|
||||||
+ rightPt = wx.Point(rect.x + rect.width - 2, int(rect.y + (rect.height / 10)*5))
|
|
||||||
else:
|
|
||||||
- leftPt = wx.Point(rect.x, rect.y + (rect.height / 2))
|
|
||||||
- rightPt = wx.Point(rect.x + rect.width - 2, rect.y + (rect.height / 2))
|
|
||||||
+ leftPt = wx.Point(rect.x, int(rect.y + (rect.height / 2)))
|
|
||||||
+ rightPt = wx.Point(rect.x + rect.width - 2, int(rect.y + (rect.height / 2)))
|
|
||||||
|
|
||||||
# Define the top region
|
|
||||||
top = wx.Rect(rect.GetTopLeft(), rightPt)
|
|
||||||
@@ -2765,7 +2765,7 @@ class FNBRendererFirefox2(FNBRenderer):
|
|
||||||
if pageTextColour is not None:
|
|
||||||
dc.SetTextForeground(pageTextColour)
|
|
||||||
|
|
||||||
- dc.DrawText(pc.GetPageText(tabIdx), posx + textOffset, imageYCoord)
|
|
||||||
+ dc.DrawText(pc.GetPageText(tabIdx), int(posx + textOffset), imageYCoord)
|
|
||||||
|
|
||||||
# draw 'x' on tab (if enabled)
|
|
||||||
if pc.HasAGWFlag(FNB_X_ON_TAB) and tabIdx == pc.GetSelection():
|
|
||||||
--- a/wx/svg/__init__.py
|
|
||||||
+++ b/wx/svg/__init__.py
|
|
||||||
@@ -132,8 +132,8 @@ class SVGimage(SVGimageBase):
|
|
||||||
"""
|
|
||||||
size = wx.Size(*size)
|
|
||||||
if window:
|
|
||||||
- size.width *= window.GetContentScaleFactor()
|
|
||||||
- size.height *= window.GetContentScaleFactor()
|
|
||||||
+ size.width = int(size.width * window.GetContentScaleFactor())
|
|
||||||
+ size.height = int(size.height * window.GetContentScaleFactor())
|
|
||||||
|
|
||||||
# We can only have one overall scale factor for both dimensions with
|
|
||||||
# this rasterization method, so chose either the minimum of width or
|
|
@ -1,20 +0,0 @@
|
|||||||
diff -U 3 -H -w -E -d -r -x .osc -- a/sip/cpp/sip_corewxTextCtrl.cpp b/sip/cpp/sip_corewxTextCtrl.cpp
|
|
||||||
--- a/sip/cpp/sip_corewxTextCtrl.cpp
|
|
||||||
+++ b/sip/cpp/sip_corewxTextCtrl.cpp
|
|
||||||
@@ -55,12 +55,16 @@
|
|
||||||
{
|
|
||||||
#ifdef __WXMSW__
|
|
||||||
return self->ShowNativeCaret(show);
|
|
||||||
+ #else
|
|
||||||
+ return false;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
bool _wxTextCtrl_HideNativeCaret(wxTextCtrl* self)
|
|
||||||
{
|
|
||||||
#ifdef __WXMSW__
|
|
||||||
return self->HideNativeCaret();
|
|
||||||
+ #else
|
|
||||||
+ return false;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
void _wxTextCtrl_write(wxTextCtrl* self, const wxString* text)
|
|
@ -1,3 +1,38 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Sat Aug 13 23:03:31 UTC 2022 - Stefan Brüns <stefan.bruens@rwth-aachen.de>
|
||||||
|
|
||||||
|
- Update to relase 4.2.0, matching wxWidgets 3.2.0
|
||||||
|
For a detailed changelog, see
|
||||||
|
https://www.wxpython.org/news/2022-08-07-wxpython-411-release/index.html
|
||||||
|
- Drop patch obsoleted by upstream changes:
|
||||||
|
* 0002-SIP-6.5-compat.patch
|
||||||
|
- Do not depend on pip for downloading in wxget, add
|
||||||
|
0003-Make-pip-usage-in-wxget-optional.patch
|
||||||
|
- Fix a wrong type size on 32 bit archs, add
|
||||||
|
0004-Fix-time_t-ETG-typedef-extend-DateTime.FromTimeT-tes.patch
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Sun Jun 26 13:46:42 UTC 2022 - Stefan Brüns <stefan.bruens@rwth-aachen.de>
|
||||||
|
|
||||||
|
- Update to current git version for wxWidgets 3.1.6/3.1.7
|
||||||
|
compatibility.
|
||||||
|
- Drop upstream patches:
|
||||||
|
* fix_no_return_in_nonvoid.patch
|
||||||
|
* wxPython-4.1.1-fix-overrides.patch
|
||||||
|
* 2039-bunch-py310-fixes.patch
|
||||||
|
* additional-310-fixes.patch
|
||||||
|
- Regenerate bindings from wxWidgets 3.1.7 code
|
||||||
|
- Allow SIP generation with SIP 6.x < 6.6,
|
||||||
|
* 0001-Only-import-attrdict-where-needed.patch
|
||||||
|
* 0002-SIP-6.5-compat.patch
|
||||||
|
- Add patches for test suite (pending):
|
||||||
|
* 0001-Check-HSV-values-in-image-test.patch
|
||||||
|
* 0001-Fix-overflow-check-for-wxUIntPtr-type.patch
|
||||||
|
- Add some more dependencies required for the test suite
|
||||||
|
- Disable some tests which can not succeed
|
||||||
|
- Enable test suite by default
|
||||||
|
- Do not ship copy of wxWidgets locale
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Wed Jan 5 11:12:25 UTC 2022 - Ben Greiner <code@bnavigator.de>
|
Wed Jan 5 11:12:25 UTC 2022 - Ben Greiner <code@bnavigator.de>
|
||||||
|
|
||||||
|
@ -17,8 +17,13 @@
|
|||||||
|
|
||||||
|
|
||||||
%define X_display ":98"
|
%define X_display ":98"
|
||||||
%bcond_with test
|
%bcond_without test
|
||||||
%bcond_without syswx
|
%bcond_without syswx
|
||||||
|
# We rebuild the ETG and SIP files for two reasons:
|
||||||
|
# - Fixing a bug in the ETG time_t typedef (see patch)
|
||||||
|
# - Compatibility with SIP 6.5.x, for Leap 15.x
|
||||||
|
%bcond_without rebuild_sip
|
||||||
|
|
||||||
%if %{with syswx}
|
%if %{with syswx}
|
||||||
%define wx_args --use_syswx --gtk3 -v
|
%define wx_args --use_syswx --gtk3 -v
|
||||||
%else
|
%else
|
||||||
@ -40,9 +45,6 @@ ExclusiveArch: donotbuild
|
|||||||
# Extraneous build_flavors and skips are excluded automatically so future
|
# Extraneous build_flavors and skips are excluded automatically so future
|
||||||
# additions can be included here early and old flavors can be removed some time
|
# additions can be included here early and old flavors can be removed some time
|
||||||
# after the global drop in Factory.
|
# after the global drop in Factory.
|
||||||
%if "%flavor" != "python36"
|
|
||||||
%define skip_python36 1
|
|
||||||
%endif
|
|
||||||
%if "%flavor" != "python38"
|
%if "%flavor" != "python38"
|
||||||
%define skip_python38 1
|
%define skip_python38 1
|
||||||
%endif
|
%endif
|
||||||
@ -52,6 +54,9 @@ ExclusiveArch: donotbuild
|
|||||||
%if "%flavor" != "python310"
|
%if "%flavor" != "python310"
|
||||||
%define skip_python310 1
|
%define skip_python310 1
|
||||||
%endif
|
%endif
|
||||||
|
%if "%flavor" != "python311"
|
||||||
|
%define skip_python311 1
|
||||||
|
%endif
|
||||||
%else
|
%else
|
||||||
# SLE/Leap: python3 only
|
# SLE/Leap: python3 only
|
||||||
%if "%flavor" != "python3"
|
%if "%flavor" != "python3"
|
||||||
@ -76,7 +81,7 @@ ExclusiveArch: donotbuild
|
|||||||
%endif
|
%endif
|
||||||
|
|
||||||
Name: %{pprefix}-wxPython
|
Name: %{pprefix}-wxPython
|
||||||
Version: 4.1.1
|
Version: 4.2.0
|
||||||
Release: 0
|
Release: 0
|
||||||
Summary: The "Phoenix" variant of the wxWidgets Python bindings
|
Summary: The "Phoenix" variant of the wxWidgets Python bindings
|
||||||
License: GPL-2.0-or-later
|
License: GPL-2.0-or-later
|
||||||
@ -84,18 +89,18 @@ Group: System/Libraries
|
|||||||
URL: https://github.com/wxWidgets/Phoenix
|
URL: https://github.com/wxWidgets/Phoenix
|
||||||
Source: https://files.pythonhosted.org/packages/source/w/wxPython/wxPython-%{version}.tar.gz
|
Source: https://files.pythonhosted.org/packages/source/w/wxPython/wxPython-%{version}.tar.gz
|
||||||
Source1: python-wxPython-rpmlintrc
|
Source1: python-wxPython-rpmlintrc
|
||||||
# PATCH-FIX-OPENSUSE fix_no_return_in_nonvoid.patch -- Fix lack of return in nonvoid functions
|
|
||||||
Patch0: fix_no_return_in_nonvoid.patch
|
|
||||||
# PATCH-FIX-OPENSUSE
|
# PATCH-FIX-OPENSUSE
|
||||||
Patch1: use_stl_build.patch
|
Patch1: use_stl_build.patch
|
||||||
# PATCH-FIX-UPSTREAM wxPython-4.1.1-fix-overrides.patch -- Fix build with wxWidgets 3.1.5 (gh#wxWidgets/Phoenix#1909)
|
# PATCH-FIX-UPSTREAM
|
||||||
Patch2: wxPython-4.1.1-fix-overrides.patch
|
Patch2: 0001-Only-import-attrdict-where-needed.patch
|
||||||
# PATCH-FIX-UPSTREAM 2039-bunch-py310-fixes.patch gh#wxWidgets/Phoenix#2039 mcepl@suse.com
|
# PATCH-FIX-UPSTREAM - https://github.com/wxWidgets/Phoenix/pull/2232
|
||||||
# Fix a bunch of Python 3.10 issues with pure-Python classes and demos
|
Patch4: 0003-Make-pip-usage-in-wxget-optional.patch
|
||||||
Patch3: 2039-bunch-py310-fixes.patch
|
# PATCH-FIX-OPENSUSE
|
||||||
# PATCH-FIX-UPSTREAM additional-310-fixes.patch bsc#[0-9]+ mcepl@suse.com
|
Patch5: 0004-Fix-time_t-ETG-typedef-extend-DateTime.FromTimeT-tes.patch
|
||||||
# collection of patches:
|
# PATCH-FIX-OPENSUSE - Test fixes/additions:
|
||||||
Patch4: additional-310-fixes.patch
|
Patch112: 0001-Check-HSV-values-in-image-test.patch
|
||||||
|
# PATCH-FIX-UPSTREAM - https://github.com/wxWidgets/Phoenix/pull/2233
|
||||||
|
Patch113: 0001-Fix-overflow-check-for-wxUIntPtr-type.patch
|
||||||
BuildRequires: %{python_module base}
|
BuildRequires: %{python_module base}
|
||||||
BuildRequires: %{python_module devel}
|
BuildRequires: %{python_module devel}
|
||||||
BuildRequires: %{python_module requests}
|
BuildRequires: %{python_module requests}
|
||||||
@ -105,7 +110,10 @@ BuildRequires: fdupes
|
|||||||
BuildRequires: pkgconfig
|
BuildRequires: pkgconfig
|
||||||
BuildRequires: python-rpm-macros
|
BuildRequires: python-rpm-macros
|
||||||
%if %{with syswx}
|
%if %{with syswx}
|
||||||
BuildRequires: wxGTK3-devel >= 3.1.5
|
BuildRequires: %{python_module sip6-devel >= 6.5.1}
|
||||||
|
BuildRequires: waf
|
||||||
|
BuildRequires: wxGTK3-devel >= 3.2.0
|
||||||
|
BuildRequires: wxWidgets-3_2-doc-xml >= 3.2.0
|
||||||
%else
|
%else
|
||||||
BuildRequires: freeglut-devel
|
BuildRequires: freeglut-devel
|
||||||
BuildRequires: gstreamer-plugins-base-devel
|
BuildRequires: gstreamer-plugins-base-devel
|
||||||
@ -141,9 +149,10 @@ BuildRequires: %{python_module numpy}
|
|||||||
BuildRequires: %{python_module pytest-xdist}
|
BuildRequires: %{python_module pytest-xdist}
|
||||||
BuildRequires: %{python_module pytest}
|
BuildRequires: %{python_module pytest}
|
||||||
BuildRequires: %{python_module six}
|
BuildRequires: %{python_module six}
|
||||||
|
BuildRequires: Mesa-dri
|
||||||
# Need at least one font installed
|
# Need at least one font installed
|
||||||
BuildRequires: google-opensans-fonts
|
BuildRequires: google-opensans-fonts
|
||||||
BuildRequires: wxWidgets-lang
|
# BuildRequires: wxWidgets-lang
|
||||||
BuildRequires: xorg-x11-server
|
BuildRequires: xorg-x11-server
|
||||||
BuildRequires: pkgconfig(cppunit)
|
BuildRequires: pkgconfig(cppunit)
|
||||||
%endif
|
%endif
|
||||||
@ -175,6 +184,13 @@ Provides translations to the package %{name}.
|
|||||||
|
|
||||||
%prep
|
%prep
|
||||||
%autosetup -n wxPython-%{version} -p1
|
%autosetup -n wxPython-%{version} -p1
|
||||||
|
# Lower minimum Python version
|
||||||
|
sed -i -e '/check_python_version/ s@3,7,0@3,6,0@' wscript
|
||||||
|
|
||||||
|
# Reuse locale from wxWidgets package
|
||||||
|
%if %{with syswx}
|
||||||
|
rm -Rf wx/locale
|
||||||
|
%endif
|
||||||
|
|
||||||
sed -i -e '/^#!\//, 1d' wx/py/*.py
|
sed -i -e '/^#!\//, 1d' wx/py/*.py
|
||||||
sed -i -e '/^#!\//, 1d' wx/tools/*.py
|
sed -i -e '/^#!\//, 1d' wx/tools/*.py
|
||||||
@ -183,7 +199,30 @@ echo "# empty module" >> wx/lib/pubsub/core/itopicdefnprovider.py
|
|||||||
|
|
||||||
%build
|
%build
|
||||||
export CFLAGS="%{optflags}"
|
export CFLAGS="%{optflags}"
|
||||||
|
|
||||||
|
%if %{with rebuild_sip}
|
||||||
|
# Save LICENSE* files from bundled siplib
|
||||||
|
mv sip/siplib{,_old}
|
||||||
|
|
||||||
export DOXYGEN=%{_bindir}/doxygen
|
export DOXYGEN=%{_bindir}/doxygen
|
||||||
|
export SIP=%{_bindir}/sip
|
||||||
|
export WAF=%{_bindir}/waf
|
||||||
|
mkdir -p /tmp/wxxml/docs/doxygen/out/
|
||||||
|
rm -f /tmp/wxxml/docs/doxygen/out/xml
|
||||||
|
cp ext/wxWidgets/docs/*.txt /tmp/wxxml/docs/
|
||||||
|
ln -sf %{_docdir}/wxWidgets*doc-xml /tmp/wxxml/docs/doxygen/out/xml
|
||||||
|
export WXWIN=/tmp/wxxml/
|
||||||
|
|
||||||
|
%python_exec build.py touch %{wx_args}
|
||||||
|
%python_exec build.py etg --nodoc %{wx_args}
|
||||||
|
%python_exec build.py sip %{wx_args}
|
||||||
|
cp sip/siplib_old/LICENSE* sip/siplib/
|
||||||
|
if [ ! -e sip/siplib/sip_array.c ]; then
|
||||||
|
cp sip/siplib/{,sip_}array.c
|
||||||
|
cp sip/siplib/{,sip_}array.h
|
||||||
|
fi
|
||||||
|
%endif
|
||||||
|
|
||||||
%python_exec build.py build %{wx_args}
|
%python_exec build.py build %{wx_args}
|
||||||
|
|
||||||
%install
|
%install
|
||||||
@ -204,7 +243,9 @@ export DOXYGEN=%{_bindir}/doxygen
|
|||||||
%python_clone -a %{buildroot}%{_bindir}/wxdocs
|
%python_clone -a %{buildroot}%{_bindir}/wxdocs
|
||||||
%python_clone -a %{buildroot}%{_bindir}/wxget
|
%python_clone -a %{buildroot}%{_bindir}/wxget
|
||||||
|
|
||||||
|
%if %{without syswx}
|
||||||
%find_lang wxstd
|
%find_lang wxstd
|
||||||
|
%endif
|
||||||
|
|
||||||
%check
|
%check
|
||||||
%if %{with test}
|
%if %{with test}
|
||||||
@ -225,8 +266,13 @@ mv wx wx_temp
|
|||||||
%pytest_arch --forked -n 1 -k 'test_uiaction or test_mousemanager' unittests/
|
%pytest_arch --forked -n 1 -k 'test_uiaction or test_mousemanager' unittests/
|
||||||
# Skip Auto ID management test (only enabled on Windows)
|
# Skip Auto ID management test (only enabled on Windows)
|
||||||
# Skip Frame restore (requires a window manager)
|
# Skip Frame restore (requires a window manager)
|
||||||
|
# Skip Locale.GetString, we do not ship translations for wxWidgets-3_2
|
||||||
|
# Skip wx.lib.pubsub, fails due to PYTHONDONTWRITEBYTECODE, also deprecated for pypubsub
|
||||||
# Skip UiAction tests (already done)
|
# Skip UiAction tests (already done)
|
||||||
%pytest_arch --forked -n auto -k '(not test_newIdRef03) and (not test_uiaction) and (not test_mousemanager) and (not test_frameRestore)' unittests/
|
%{pytest_arch --forked -n 4 -k \
|
||||||
|
'(not test_newIdRef03) and (not test_uiaction) and (not test_mousemanager) and (not test_frameRestore) and (not test_intlGetString) and (not lib_pubsub_Except) and (not test_xrc7)' \
|
||||||
|
unittests/
|
||||||
|
}
|
||||||
|
|
||||||
mv wx_temp wx
|
mv wx_temp wx
|
||||||
%endif
|
%endif
|
||||||
@ -252,13 +298,17 @@ mv wx_temp wx
|
|||||||
%python_alternative %{_bindir}/wxdemo
|
%python_alternative %{_bindir}/wxdemo
|
||||||
%python_alternative %{_bindir}/wxdocs
|
%python_alternative %{_bindir}/wxdocs
|
||||||
%python_alternative %{_bindir}/wxget
|
%python_alternative %{_bindir}/wxget
|
||||||
%{python_sitearch}/wxPython-%{version}-py*.egg-info
|
%{python_sitearch}/wxPython-*-py*.egg-info
|
||||||
%{python_sitearch}/wx/
|
%{python_sitearch}/wx/
|
||||||
|
%if %{without syswx}
|
||||||
%exclude %{python_sitearch}/wx/locale/
|
%exclude %{python_sitearch}/wx/locale/
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%if %{without syswx}
|
||||||
%files lang -f wxstd.lang
|
%files lang -f wxstd.lang
|
||||||
%dir %{python_sitearch}/wx/locale/
|
%dir %{python_sitearch}/wx/locale/
|
||||||
%dir %{python_sitearch}/wx/locale/*
|
%dir %{python_sitearch}/wx/locale/*
|
||||||
%dir %{python_sitearch}/wx/locale/*/LC_MESSAGES
|
%dir %{python_sitearch}/wx/locale/*/LC_MESSAGES
|
||||||
|
%endif
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
--- wxPython-4.1.0/buildtools/build_wxwidgets.py_orig 2020-05-30 01:24:47.890132236 +0200
|
--- wxPython-4.1.0/buildtools/build_wxwidgets.py_orig 2020-05-30 01:24:47.890132236 +0200
|
||||||
+++ wxPython-4.1.0/buildtools/build_wxwidgets.py 2020-05-30 01:25:59.574988273 +0200
|
+++ wxPython-4.1.0/buildtools/build_wxwidgets.py 2020-05-30 01:25:59.574988273 +0200
|
||||||
@@ -362,6 +362,7 @@
|
@@ -370,6 +370,8 @@
|
||||||
else:
|
if os.path.exists(frameworkRootDir):
|
||||||
configure_opts.append("--enable-universal_binary=%s" % options.mac_universal_binary)
|
shutil.rmtree(frameworkRootDir)
|
||||||
|
|
||||||
+ configure_opts.append("--enable-stl")
|
+ configure_opts.append("--enable-stl")
|
||||||
|
+
|
||||||
print("Configure options: " + repr(configure_opts))
|
print("Configure options: " + repr(configure_opts))
|
||||||
wxBuilder = builder.AutoconfBuilder()
|
wxBuilder = builder.AutoconfBuilder()
|
||||||
|
if not options.no_config and not options.clean:
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
--- wxPython-4.1.1.orig/sip/cpp/sip_gridwxGridEvent.cpp 2020-11-21 20:10:38.000000000 +0100
|
|
||||||
+++ wxPython-4.1.1/sip/cpp/sip_gridwxGridEvent.cpp 2021-05-16 03:21:55.031555889 +0200
|
|
||||||
@@ -32,8 +32,8 @@
|
|
||||||
* this class.
|
|
||||||
*/
|
|
||||||
protected:
|
|
||||||
- int GetRow() SIP_OVERRIDE;
|
|
||||||
- int GetCol() SIP_OVERRIDE;
|
|
||||||
+ int GetRow();
|
|
||||||
+ int GetCol();
|
|
||||||
::wxEvent* Clone() const SIP_OVERRIDE;
|
|
||||||
::wxEventCategory GetEventCategory() const SIP_OVERRIDE;
|
|
||||||
|
|
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:00e5e3180ac7f2852f342ad341d57c44e7e4326de0b550b9a5c4a8361b6c3528
|
|
||||||
size 66043287
|
|
3
wxPython-4.2.0.tar.gz
Normal file
3
wxPython-4.2.0.tar.gz
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:663cebc4509d7e5d113518865fe274f77f95434c5d57bc386ed58d65ceed86c7
|
||||||
|
size 70958238
|
Loading…
Reference in New Issue
Block a user