Update to version 0.18.3; Fixes RHBZ#2186630

epel10
Fabio Valentini 2 years ago
parent 14f1e8218f
commit 815ee0f691
No known key found for this signature in database
GPG Key ID: 5AC5F572E5D410AF

1
.gitignore vendored

@ -12,3 +12,4 @@
/pyo3-0.17.3.crate /pyo3-0.17.3.crate
/pyo3-0.18.1.crate /pyo3-0.18.1.crate
/pyo3-0.18.2.crate /pyo3-0.18.2.crate
/pyo3-0.18.3.crate

@ -1,26 +0,0 @@
From 7dd21aa26aa44890eec3b9331a932b84150595c3 Mon Sep 17 00:00:00 2001
From: Fabio Valentini <decathorpe@gmail.com>
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

@ -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<PyStringData<'_>> {
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 = "哈哈🐈";

@ -1,5 +1,5 @@
--- pyo3-0.18.2/Cargo.toml 1970-01-01T00:00:01+00:00 --- pyo3-0.18.3/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 2023-05-06T20:19:17.578691+00:00
@@ -57,52 +57,6 @@ @@ -57,52 +57,6 @@
"docsrs", "docsrs",
] ]
@ -82,7 +82,7 @@
-version = "0.5.1" -version = "0.5.1"
[build-dependencies.pyo3-build-config] [build-dependencies.pyo3-build-config]
version = "0.18.2" version = "0.18.3"
@@ -254,7 +199,6 @@ @@ -254,7 +199,6 @@
"anyhow", "anyhow",
"experimental-inspect", "experimental-inspect",

@ -5,7 +5,7 @@
%global crate pyo3 %global crate pyo3
Name: rust-pyo3 Name: rust-pyo3
Version: 0.18.2 Version: 0.18.3
Release: %autorelease Release: %autorelease
Summary: Bindings to Python interpreter Summary: Bindings to Python interpreter
@ -20,11 +20,6 @@ Source: %{crates_source}
Patch: pyo3-fix-metadata.diff Patch: pyo3-fix-metadata.diff
# * skip the single doctest that depends on send_wrapper # * skip the single doctest that depends on send_wrapper
Patch: 0001-ignore-doctest-with-missing-send_wrapper-dependency.patch 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 BuildRequires: rust-packaging >= 21

@ -1 +1 @@
SHA512 (pyo3-0.18.2.crate) = b97ebc10939418d7fe3d6219921875cc7253f3aa7cd9d06b1486f8757c6d102377eb851b3a669c670423af2c80e389b736f0ce04a6cecb716c952413d06fe434 SHA512 (pyo3-0.18.3.crate) = 39f044a19a42a5e2f46049431fbe3fe10c14d12a4741cc789b42de7cbf448bcbded7fe38a0f124d994ff9bcd3d95a19305dbfdc7462331fda3e6686cc4289be5

Loading…
Cancel
Save