From 815ee0f6919adc8b54c0a9ab1fee43af6bae389a Mon Sep 17 00:00:00 2001 From: Fabio Valentini Date: Sat, 6 May 2023 22:31:12 +0200 Subject: [PATCH] Update to version 0.18.3; Fixes RHBZ#2186630 --- .gitignore | 1 + ...ests-for-little-endian-things-on-big.patch | 26 --- ...bject-state-bitfield-access-wrappers.patch | 171 ------------------ pyo3-fix-metadata.diff | 6 +- rust-pyo3.spec | 7 +- sources | 2 +- 6 files changed, 6 insertions(+), 207 deletions(-) delete mode 100644 0002-Ensure-to-skip-tests-for-little-endian-things-on-big.patch delete mode 100644 0003-add-PyASCIIObject-state-bitfield-access-wrappers.patch diff --git a/.gitignore b/.gitignore index 4568d85..7152342 100644 --- a/.gitignore +++ b/.gitignore @@ -12,3 +12,4 @@ /pyo3-0.17.3.crate /pyo3-0.18.1.crate /pyo3-0.18.2.crate +/pyo3-0.18.3.crate diff --git a/0002-Ensure-to-skip-tests-for-little-endian-things-on-big.patch b/0002-Ensure-to-skip-tests-for-little-endian-things-on-big.patch deleted file mode 100644 index 8ca694a..0000000 --- a/0002-Ensure-to-skip-tests-for-little-endian-things-on-big.patch +++ /dev/null @@ -1,26 +0,0 @@ -From 7dd21aa26aa44890eec3b9331a932b84150595c3 Mon Sep 17 00:00:00 2001 -From: Fabio Valentini -Date: Thu, 26 Jan 2023 18:35:24 +0100 -Subject: [PATCH] Ensure to skip tests for little-endian things on big-endian - arches - ---- - src/ffi/tests.rs | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -diff --git a/src/ffi/tests.rs b/src/ffi/tests.rs -index a0d3250..0800682 100644 ---- a/src/ffi/tests.rs -+++ b/src/ffi/tests.rs -@@ -87,7 +87,7 @@ fn test_timezone_from_offset() { - } - - #[test] --#[cfg(feature = "macros")] -+#[cfg(all(feature = "macros", target_endian = "little"))] - #[cfg_attr(target_arch = "wasm32", ignore)] // DateTime import fails on wasm for mysterious reasons - fn test_timezone_from_offset_and_name() { - use crate::types::PyDelta; --- -2.39.1 - diff --git a/0003-add-PyASCIIObject-state-bitfield-access-wrappers.patch b/0003-add-PyASCIIObject-state-bitfield-access-wrappers.patch deleted file mode 100644 index 794640d..0000000 --- a/0003-add-PyASCIIObject-state-bitfield-access-wrappers.patch +++ /dev/null @@ -1,171 +0,0 @@ -diff --git a/src/ffi/tests.rs b/src/ffi/tests.rs -index a0d32504497..97e838cf527 100644 ---- a/src/ffi/tests.rs -+++ b/src/ffi/tests.rs -@@ -1,9 +1,7 @@ - use crate::ffi::*; - use crate::{types::PyDict, AsPyPointer, IntoPy, Py, PyAny, Python}; - --#[cfg(target_endian = "little")] - use crate::types::PyString; --#[cfg(target_endian = "little")] - use libc::wchar_t; - - #[cfg_attr(target_arch = "wasm32", ignore)] // DateTime import fails on wasm for mysterious reasons -@@ -108,7 +106,6 @@ fn test_timezone_from_offset_and_name() { - }) - } - --#[cfg(target_endian = "little")] - #[test] - fn ascii_object_bitfield() { - let ob_base: PyObject = unsafe { std::mem::zeroed() }; -@@ -118,7 +115,7 @@ fn ascii_object_bitfield() { - length: 0, - #[cfg(not(PyPy))] - hash: 0, -- state: 0, -+ state: 0u32, - wstr: std::ptr::null_mut() as *mut wchar_t, - }; - -@@ -130,27 +127,26 @@ fn ascii_object_bitfield() { - assert_eq!(o.ready(), 0); - - for i in 0..4 { -- o.state = i; -+ o.set_interned(i); - assert_eq!(o.interned(), i); - } - - for i in 0..8 { -- o.state = i << 2; -+ o.set_kind(i); - assert_eq!(o.kind(), i); - } - -- o.state = 1 << 5; -+ o.set_compact(1); - assert_eq!(o.compact(), 1); - -- o.state = 1 << 6; -+ o.set_ascii(1); - assert_eq!(o.ascii(), 1); - -- o.state = 1 << 7; -+ o.set_ready(1); - assert_eq!(o.ready(), 1); - } - } - --#[cfg(target_endian = "little")] - #[test] - #[cfg_attr(Py_3_10, allow(deprecated))] - fn ascii() { -@@ -191,7 +187,6 @@ fn ascii() { - }) - } - --#[cfg(target_endian = "little")] - #[test] - #[cfg_attr(Py_3_10, allow(deprecated))] - fn ucs4() { -diff --git a/src/types/mod.rs b/src/types/mod.rs -index 923dfcc096d..8d3e2714383 100644 ---- a/src/types/mod.rs -+++ b/src/types/mod.rs -@@ -36,7 +36,7 @@ pub use self::pysuper::PySuper; - pub use self::sequence::PySequence; - pub use self::set::PySet; - pub use self::slice::{PySlice, PySliceIndices}; --#[cfg(all(not(Py_LIMITED_API), target_endian = "little"))] -+#[cfg(not(Py_LIMITED_API))] - pub use self::string::PyStringData; - pub use self::string::{PyString, PyString as PyUnicode}; - pub use self::traceback::PyTraceback; -diff --git a/src/types/string.rs b/src/types/string.rs -index 2dc7a506476..3998a6adf04 100644 ---- a/src/types/string.rs -+++ b/src/types/string.rs -@@ -1,6 +1,6 @@ - // Copyright (c) 2017-present PyO3 Project and Contributors - --#[cfg(all(not(Py_LIMITED_API), target_endian = "little"))] -+#[cfg(not(Py_LIMITED_API))] - use crate::exceptions::PyUnicodeDecodeError; - use crate::types::PyBytes; - use crate::{ffi, AsPyPointer, PyAny, PyResult, Python}; -@@ -12,7 +12,7 @@ use std::str; - /// - /// Python internally stores strings in various representations. This enumeration - /// represents those variations. --#[cfg(all(not(Py_LIMITED_API), target_endian = "little"))] -+#[cfg(not(Py_LIMITED_API))] - #[derive(Clone, Copy, Debug, PartialEq, Eq)] - pub enum PyStringData<'a> { - /// UCS1 representation. -@@ -25,7 +25,7 @@ pub enum PyStringData<'a> { - Ucs4(&'a [u32]), - } - --#[cfg(all(not(Py_LIMITED_API), target_endian = "little"))] -+#[cfg(not(Py_LIMITED_API))] - impl<'a> PyStringData<'a> { - /// Obtain the raw bytes backing this instance as a [u8] slice. - pub fn as_bytes(&self) -> &[u8] { -@@ -238,9 +238,7 @@ impl PyString { - /// - /// By using this API, you accept responsibility for testing that PyStringData behaves as - /// expected on the targets where you plan to distribute your software. -- /// -- /// For example, it is known not to work on big-endian platforms. -- #[cfg(all(not(Py_LIMITED_API), target_endian = "little"))] -+ #[cfg(not(Py_LIMITED_API))] - pub unsafe fn data(&self) -> PyResult> { - let ptr = self.as_ptr(); - -@@ -284,7 +282,7 @@ mod tests { - use super::*; - use crate::Python; - use crate::{PyObject, ToPyObject}; -- #[cfg(all(not(Py_LIMITED_API), target_endian = "little"))] -+ #[cfg(not(Py_LIMITED_API))] - use std::borrow::Cow; - - #[test] -@@ -347,7 +345,7 @@ mod tests { - } - - #[test] -- #[cfg(all(not(Py_LIMITED_API), target_endian = "little"))] -+ #[cfg(not(Py_LIMITED_API))] - fn test_string_data_ucs1() { - Python::with_gil(|py| { - let s = PyString::new(py, "hello, world"); -@@ -360,7 +358,7 @@ mod tests { - } - - #[test] -- #[cfg(all(not(Py_LIMITED_API), target_endian = "little"))] -+ #[cfg(not(Py_LIMITED_API))] - fn test_string_data_ucs1_invalid() { - Python::with_gil(|py| { - // 0xfe is not allowed in UTF-8. -@@ -386,7 +384,7 @@ mod tests { - } - - #[test] -- #[cfg(all(not(Py_LIMITED_API), target_endian = "little"))] -+ #[cfg(not(Py_LIMITED_API))] - fn test_string_data_ucs2() { - Python::with_gil(|py| { - let s = py.eval("'foo\\ud800'", None, None).unwrap(); -@@ -428,7 +426,7 @@ mod tests { - } - - #[test] -- #[cfg(all(not(Py_LIMITED_API), target_endian = "little"))] -+ #[cfg(not(Py_LIMITED_API))] - fn test_string_data_ucs4() { - Python::with_gil(|py| { - let s = "哈哈🐈"; diff --git a/pyo3-fix-metadata.diff b/pyo3-fix-metadata.diff index 62dd1e4..2d57548 100644 --- a/pyo3-fix-metadata.diff +++ b/pyo3-fix-metadata.diff @@ -1,5 +1,5 @@ ---- pyo3-0.18.2/Cargo.toml 1970-01-01T00:00:01+00:00 -+++ pyo3-0.18.2/Cargo.toml 2023-03-26T17:20:42.698756+00:00 +--- pyo3-0.18.3/Cargo.toml 1970-01-01T00:00:01+00:00 ++++ pyo3-0.18.3/Cargo.toml 2023-05-06T20:19:17.578691+00:00 @@ -57,52 +57,6 @@ "docsrs", ] @@ -82,7 +82,7 @@ -version = "0.5.1" [build-dependencies.pyo3-build-config] - version = "0.18.2" + version = "0.18.3" @@ -254,7 +199,6 @@ "anyhow", "experimental-inspect", diff --git a/rust-pyo3.spec b/rust-pyo3.spec index 0dbf576..5dae3dc 100644 --- a/rust-pyo3.spec +++ b/rust-pyo3.spec @@ -5,7 +5,7 @@ %global crate pyo3 Name: rust-pyo3 -Version: 0.18.2 +Version: 0.18.3 Release: %autorelease Summary: Bindings to Python interpreter @@ -20,11 +20,6 @@ Source: %{crates_source} Patch: pyo3-fix-metadata.diff # * skip the single doctest that depends on send_wrapper Patch: 0001-ignore-doctest-with-missing-send_wrapper-dependency.patch -# * skip a little-endian-specific test on big-endian arches -Patch: 0002-Ensure-to-skip-tests-for-little-endian-things-on-big.patch -# * backport upstreamed patch make PyASCIIObject available on big-endian arches -# https://github.com/PyO3/pyo3/commit/40d6d47 -Patch: 0003-add-PyASCIIObject-state-bitfield-access-wrappers.patch BuildRequires: rust-packaging >= 21 diff --git a/sources b/sources index c1dff32..48661ac 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -SHA512 (pyo3-0.18.2.crate) = b97ebc10939418d7fe3d6219921875cc7253f3aa7cd9d06b1486f8757c6d102377eb851b3a669c670423af2c80e389b736f0ce04a6cecb716c952413d06fe434 +SHA512 (pyo3-0.18.3.crate) = 39f044a19a42a5e2f46049431fbe3fe10c14d12a4741cc789b42de7cbf448bcbded7fe38a0f124d994ff9bcd3d95a19305dbfdc7462331fda3e6686cc4289be5