Skip to content

Commit

Permalink
Merge pull request #3813 from davidhewitt/nightly-2024-02-08
Browse files Browse the repository at this point in the history
ci: allow some dead code warnings on nightly
  • Loading branch information
davidhewitt authored Feb 8, 2024
2 parents 030a618 + bcb7b88 commit 9bb0011
Show file tree
Hide file tree
Showing 5 changed files with 18 additions and 12 deletions.
5 changes: 5 additions & 0 deletions guide/src/trait_bounds.md
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ class Model:
The following wrapper will call the Python model from Rust, using a struct to hold the model as a `PyAny` object:

```rust
# #![allow(dead_code)]
use pyo3::prelude::*;

# pub trait Model {
Expand Down Expand Up @@ -162,6 +163,7 @@ However, we can write a second wrapper around these functions to call them direc
This wrapper will also perform the type conversions between Python and Rust.

```rust
# #![allow(dead_code)]
# use pyo3::prelude::*;
#
# pub trait Model {
Expand Down Expand Up @@ -330,6 +332,7 @@ Let's modify the code performing the type conversion to give a helpful error mes
We used in our `get_results` method the following call that performs the type conversion:

```rust
# #![allow(dead_code)]
# use pyo3::prelude::*;
#
# pub trait Model {
Expand Down Expand Up @@ -382,6 +385,7 @@ impl Model for UserModel {
Let's break it down in order to perform better error handling:

```rust
# #![allow(dead_code)]
# use pyo3::prelude::*;
#
# pub trait Model {
Expand Down Expand Up @@ -460,6 +464,7 @@ Because of this, we can write a function wrapper that takes the `UserModel`--whi
It is also required to make the struct public.

```rust
# #![allow(dead_code)]
use pyo3::prelude::*;

pub trait Model {
Expand Down
1 change: 1 addition & 0 deletions src/marker.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
//! defined as the following:
//!
//! ```rust
//! # #![allow(dead_code)]
//! pub unsafe trait Ungil {}
//!
//! unsafe impl<T: Send> Ungil for T {}
Expand Down
10 changes: 5 additions & 5 deletions tests/ui/not_send.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -7,23 +7,23 @@ error[E0277]: `*mut pyo3::Python<'static>` cannot be shared between threads safe
| required by a bound introduced by this call
|
= help: within `pyo3::Python<'_>`, the trait `Sync` is not implemented for `*mut pyo3::Python<'static>`
note: required because it appears within the type `PhantomData<*mut Python<'static>>`
note: required because it appears within the type `PhantomData<*mut pyo3::Python<'static>>`
--> $RUST/core/src/marker.rs
|
| pub struct PhantomData<T: ?Sized>;
| ^^^^^^^^^^^
note: required because it appears within the type `NotSend`
note: required because it appears within the type `impl_::not_send::NotSend`
--> src/impl_/not_send.rs
|
| pub(crate) struct NotSend(PhantomData<*mut Python<'static>>);
| ^^^^^^^
= note: required because it appears within the type `(&GILGuard, NotSend)`
note: required because it appears within the type `PhantomData<(&GILGuard, NotSend)>`
= note: required because it appears within the type `(&pyo3::gil::GILGuard, impl_::not_send::NotSend)`
note: required because it appears within the type `PhantomData<(&pyo3::gil::GILGuard, impl_::not_send::NotSend)>`
--> $RUST/core/src/marker.rs
|
| pub struct PhantomData<T: ?Sized>;
| ^^^^^^^^^^^
note: required because it appears within the type `Python<'_>`
note: required because it appears within the type `pyo3::Python<'_>`
--> src/marker.rs
|
| pub struct Python<'py>(PhantomData<(&'py GILGuard, NotSend)>);
Expand Down
12 changes: 6 additions & 6 deletions tests/ui/not_send2.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -10,28 +10,28 @@ error[E0277]: `*mut pyo3::Python<'static>` cannot be shared between threads safe
| |_________^ `*mut pyo3::Python<'static>` cannot be shared between threads safely
|
= help: within `pyo3::Bound<'_, PyString>`, the trait `Sync` is not implemented for `*mut pyo3::Python<'static>`
note: required because it appears within the type `PhantomData<*mut Python<'static>>`
note: required because it appears within the type `PhantomData<*mut pyo3::Python<'static>>`
--> $RUST/core/src/marker.rs
|
| pub struct PhantomData<T: ?Sized>;
| ^^^^^^^^^^^
note: required because it appears within the type `NotSend`
note: required because it appears within the type `impl_::not_send::NotSend`
--> src/impl_/not_send.rs
|
| pub(crate) struct NotSend(PhantomData<*mut Python<'static>>);
| ^^^^^^^
= note: required because it appears within the type `(&GILGuard, NotSend)`
note: required because it appears within the type `PhantomData<(&GILGuard, NotSend)>`
= note: required because it appears within the type `(&pyo3::gil::GILGuard, impl_::not_send::NotSend)`
note: required because it appears within the type `PhantomData<(&pyo3::gil::GILGuard, impl_::not_send::NotSend)>`
--> $RUST/core/src/marker.rs
|
| pub struct PhantomData<T: ?Sized>;
| ^^^^^^^^^^^
note: required because it appears within the type `Python<'_>`
note: required because it appears within the type `pyo3::Python<'_>`
--> src/marker.rs
|
| pub struct Python<'py>(PhantomData<(&'py GILGuard, NotSend)>);
| ^^^^^^
note: required because it appears within the type `Bound<'_, PyString>`
note: required because it appears within the type `pyo3::Bound<'_, PyString>`
--> src/instance.rs
|
| pub struct Bound<'py, T>(Python<'py>, ManuallyDrop<Py<T>>);
Expand Down
2 changes: 1 addition & 1 deletion tests/ui/traverse.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ error[E0308]: mismatched types
| |___________________^ expected fn pointer, found fn item
|
= note: expected fn pointer `for<'a, 'b> fn(&'a TraverseTriesToTakePyRef, PyVisit<'b>) -> Result<(), PyTraverseError>`
found fn item `for<'a, 'b> fn(pyo3::PyRef<'a, TraverseTriesToTakePyRef>, PyVisit<'b>) {TraverseTriesToTakePyRef::__traverse__}`
found fn item `for<'a, 'b> fn(pyo3::PyRef<'a, TraverseTriesToTakePyRef, >, PyVisit<'b>) {TraverseTriesToTakePyRef::__traverse__}`
note: function defined here
--> src/impl_/pymethods.rs
|
Expand Down

0 comments on commit 9bb0011

Please sign in to comment.