diff --git a/catch-gzip-error.patch b/catch-gzip-error.patch
deleted file mode 100644
index 41e42cc..0000000
--- a/catch-gzip-error.patch
+++ /dev/null
@@ -1,30 +0,0 @@
-diff -ur feedparser-5.2.1-orig/feedparser/feedparser.py feedparser-5.2.1/feedparser/feedparser.py
---- feedparser-5.2.1-orig/feedparser/feedparser.py 2015-07-24 12:00:04.000000000 +0700
-+++ feedparser-5.2.1/feedparser/feedparser.py 2019-03-31 02:26:41.242238792 +0700
-@@ -3865,12 +3869,12 @@
- if gzip and 'gzip' in http_headers.get('content-encoding', ''):
- try:
- data = gzip.GzipFile(fileobj=_StringIO(data)).read()
-- except (IOError, struct.error), e:
-+ except (EOFError, IOError, struct.error), e:
- # IOError can occur if the gzip header is bad.
- # struct.error can occur if the data is damaged.
- result['bozo'] = 1
- result['bozo_exception'] = e
-- if isinstance(e, struct.error):
-+ if isinstance(e, (EOFError, struct.error)):
- # A gzip header was found but the data is corrupt.
- # Ideally, we should re-request the feed without the
- # 'Accept-encoding: gzip' header, but we don't.
-diff -ur feedparser-5.2.1-orig/feedparser/feedparsertest.py feedparser-5.2.1/feedparser/feedparsertest.py
---- feedparser-5.2.1-orig/feedparser/feedparsertest.py 2015-07-24 11:45:09.000000000 +0700
-+++ feedparser-5.2.1/feedparser/feedparsertest.py 2019-03-31 04:02:14.470216076 +0700
-@@ -448,7 +456,7 @@
- def test_gzip_struct_error(self):
- f = feedparser.parse('http://localhost:8097/tests/compression/gzip-struct-error.gz')
- self.assertEqual(f.bozo, 1)
-- self.assertTrue(isinstance(f.bozo_exception, struct.error))
-+ self.assertTrue(isinstance(f.bozo_exception, (EOFError, struct.error)))
- def test_zlib_good(self):
- f = feedparser.parse('http://localhost:8097/tests/compression/deflate.z')
- self.assertEqual(f.version, 'atom10')
diff --git a/feedparser-5.2.1.tar.bz2 b/feedparser-5.2.1.tar.bz2
deleted file mode 100644
index 2789a32..0000000
--- a/feedparser-5.2.1.tar.bz2
+++ /dev/null
@@ -1,3 +0,0 @@
-version https://git-lfs.github.com/spec/v1
-oid sha256:ce875495c90ebd74b179855449040003a1beb40cd13d5f037a0654251e260b02
-size 192328
diff --git a/feedparser-6.0.0.tar.gz b/feedparser-6.0.0.tar.gz
new file mode 100644
index 0000000..3df250c
--- /dev/null
+++ b/feedparser-6.0.0.tar.gz
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:a13fb1f26a7da985b51e6d1e91102fb1b1e5eb5d550a192643049a527bb24b0d
+size 285322
diff --git a/non-ascii-entity-hiding.patch b/non-ascii-entity-hiding.patch
deleted file mode 100644
index 86e15c2..0000000
--- a/non-ascii-entity-hiding.patch
+++ /dev/null
@@ -1,17 +0,0 @@
-diff -ur feedparser-5.2.1-orig/feedparser/feedparsertest.py feedparser-5.2.1/feedparser/feedparsertest.py
---- feedparser-5.2.1-orig/feedparser/feedparsertest.py 2015-07-24 11:45:09.000000000 +0700
-+++ feedparser-5.2.1/feedparser/feedparsertest.py 2019-03-31 04:02:14.470216076 +0700
-@@ -273,6 +273,13 @@
- &exponential3;"""
- doc = codecs.BOM_UTF16_BE + doc.encode('utf-16be')
- result = feedparser.parse(doc)
-+ if sys.version_info >= (3, 5):
-+ # While this isnt the expected result, it is verification that
-+ # non-ASCII-compatible encodings cant hide nasty stuff.
-+ # Instead, nothing is loaded, which is a bug in a different
-+ # area.
-+ self.assertEqual(result['feed'], {})
-+ return
- self.assertEqual(result['feed']['title'], u'&exponential3')
- def test_gb2312_converted_to_gb18030_in_xml_encoding(self):
- # \u55de was chosen because it exists in gb18030 but not gb2312
diff --git a/py37.patch b/py37.patch
deleted file mode 100644
index c50d5a3..0000000
--- a/py37.patch
+++ /dev/null
@@ -1,16 +0,0 @@
-diff -ur feedparser-5.2.1-orig/feedparser/feedparser.py feedparser-5.2.1/feedparser/feedparser.py
---- feedparser-5.2.1-orig/feedparser/feedparser.py 2015-07-24 12:00:04.000000000 +0700
-+++ feedparser-5.2.1/feedparser/feedparser.py 2019-03-31 02:26:41.242238792 +0700
-@@ -3764,7 +3764,11 @@
- latlons = itertools.imap(float, value.strip().replace(',', ' ').split())
- nxt = latlons.next
- while True:
-- t = [nxt(), nxt()][::swap and -1 or 1]
-+ # Python 3.7 support
-+ try:
-+ t = [nxt(), nxt()][::swap and -1 or 1]
-+ except StopIteration:
-+ return
- if dims == 3:
- t.append(nxt())
- yield tuple(t)
diff --git a/python-feedparser.changes b/python-feedparser.changes
index 9f1b6d7..3e5a10d 100644
--- a/python-feedparser.changes
+++ b/python-feedparser.changes
@@ -1,3 +1,43 @@
+-------------------------------------------------------------------
+Mon Sep 14 20:10:18 UTC 2020 - BenoƮt Monin
+
+- update to version 6.0.0:
+ * Support Python 3.6, 3.7, 3.8 and 3.9
+ * Drop support for Python 2.4 through 2.7, and Python 3.0 through
+ 3.5 (#169)
+ * Convert feedparser from a monolithic file to a package
+ * feedparser.parse(sanitize_html=bool) argument replaces the
+ feedparser.SANITIZE_HTML global
+ * feedparser.parse(resolve_relative_uris=bool) replaces the
+ feedparser.RESOLVE_RELATIVE_URIS global
+ * Unify the codebase so that 2to3 conversion is no longer
+ required
+ * Remove references to iconv_codecs
+ * Update the Creative Commons namespace URI's
+ * Update the default User-Agent name and URL
+ * Support Middle European (Summer) Time timezones (#20)
+ * Pass data to lazy_chardet_encoding() (#50)
+ * Document that datetimes are returned in UTC (#51)
+ * Remove cjkpython references in the documentation (#57)
+ * Resolve ResourceWarnings thrown during unit tests (#170)
+ * Fix tox build failures (#213)
+ * Use base64.decodebytes() directly to support Python 3.9 (#201)
+ * Fix Python 3.8 urllib.parse.splittype() deprecation warning
+ (#211)
+ * Support parsing colons in RFC822 timezones (#144)
+ * Add `chardet` as an optional tox environment dependency
+ * Fix the Big5 unit test that fails when chardet is installed
+ (#184)
+- build the package only for python3
+- drop py37.patch: fixed upstream
+- drop non-ascii-entity-hiding.patch: fixed upstream
+- drop catch-gzip-error.patch: fixed upstream
+- fix build requires for chardet and sgmllib3k
+- remove chmod on all source files: fixed upstream
+- drop moving around source files: reworked upstream
+- run the tests as described by upstream
+- fix the list of packaged files
+
-------------------------------------------------------------------
Sat Mar 30 22:06:01 UTC 2019 - John Vandenberg
diff --git a/python-feedparser.spec b/python-feedparser.spec
index c422833..685ff29 100644
--- a/python-feedparser.spec
+++ b/python-feedparser.spec
@@ -1,7 +1,7 @@
#
# spec file for package python-feedparser
#
-# Copyright (c) 2019 SUSE LINUX GmbH, Nuernberg, Germany.
+# Copyright (c) 2020 SUSE LLC
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
@@ -16,35 +16,25 @@
#
+%define skip_python2 1
%{?!python_module:%define python_module() python-%{**} python3-%{**}}
Name: python-feedparser
-Version: 5.2.1
+Version: 6.0.0
Release: 0
Summary: Universal Feed Parser Module for Python
License: BSD-2-Clause
Group: Development/Libraries/Python
URL: https://github.com/kurtmckee/feedparser
-Source: https://files.pythonhosted.org/packages/source/f/feedparser/feedparser-%{version}.tar.bz2
-Patch0: py37.patch
-Patch1: non-ascii-entity-hiding.patch
-# Similar to https://github.com/kurtmckee/feedparser/commit/b3d9463.patch
-# However the "gets overwritten as xml.sax.SAXException later" is not
-# happening in version 5.2.1.
-Patch2: catch-gzip-error.patch
+Source: https://files.pythonhosted.org/packages/source/f/feedparser/feedparser-%{version}.tar.gz
+BuildRequires: %{python_module chardet}
BuildRequires: %{python_module setuptools}
+BuildRequires: %{python_module sgmllib3k}
BuildRequires: %{python_module xml}
BuildRequires: fdupes
BuildRequires: python-rpm-macros
-BuildRequires: python3-sgmllib3k
-# Tests fail in Python 2 and 3 when chardet is installed
-#BuildRequires: python3-chardet
Requires: python-xml
-# chardet is an optional dependency, but some tests fail when it is present
Recommends: python-chardet
-%ifpython3
-# If sgmllib is not available, the parser can fail with undefined local variable
-Requires: python3-sgmllib3k
-%endif
+Requires: python-sgmllib3k
BuildArch: noarch
%python_subpackages
@@ -54,17 +44,6 @@ A universal feed parser module for Python that handles RSS 0.9x, RSS 1.0, RSS
%prep
%setup -q -n feedparser-%{version}
-%autopatch -p1
-
-find . -type f -exec chmod 0644 {} \; # 5.2.1 had executable bit set on almost all files
-
-# In version 5.2.1, it contains only test data, so move it out of install
-mv feedparser/tests .
-
-# Move the test module out of the runtime install, into top level directory
-# so it can find the test data, and manually run 2to3.
-python3 -m lib2to3 -w -n -o . --add-suffix=-%{python3_bin_suffix} --no-diffs feedparser/feedparsertest.py
-mv feedparser/feedparsertest.py feedparsertest.py-%{python2_bin_suffix}
%build
%python_build
@@ -75,17 +54,13 @@ mv feedparser/feedparsertest.py feedparsertest.py-%{python2_bin_suffix}
%check
%{python_expand export PYTHONPATH=%{buildroot}%{$python_sitelib}:${PWD}
-cp feedparsertest.py-%{$python_bin_suffix} feedparsertest.py
-$python -c 'import feedparser; assert feedparser._XML_AVAILABLE == 1; assert feedparser._SGML_AVAILABLE == 1'
-$python -c 'import feedparsertest; assert feedparsertest._UTF32_AVAILABLE == 1'
-$python feedparsertest.py
+$python tests/runtests.py
}
%files %{python_files}
%license LICENSE
%doc NEWS README.rst
-%{python_sitelib}/feedparser.py*
-%pycache_only %{python_sitelib}/__pycache__/feedparser.*.py*
-%{python_sitelib}/feedparser-%{version}-py*.egg-info
+%{python_sitelib}/feedparser/
+%{python_sitelib}/feedparser-%{version}-py%{python_version}.egg-info
%changelog