-
-
Notifications
You must be signed in to change notification settings - Fork 17
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Calling pin_project with a proxy macro does not mark inner projections as pub(crate) #77
Comments
Temporary fix for taiki-e#77 Signed-off-by: John Nunley <dev@notgull.net>
The warning seems reasonable since you are passing an undocumented pub struct to pin_project!. pin_project! only downgrades the visibility of the projected struct, not the visibility of the input struct itself. |
Even if I document the struct and make its type private... pub use pin_project_lite;
#[macro_export]
macro_rules! wrapper {
($vis:vis) => {
$crate::pin_project_lite::pin_project! {
/// Docs!
$vis struct Wrapper<T> {
#[pin]
inner: T,
}
}
};
} ...I still get this error:
|
Oh, that's odd. Another possibility is that the visibility of the input was first interpreted as |
In the latter case, the reasonable workaround is probably to remove the code for visibility parsing and always use |
I checked the output from cargo-expand and it is the latter. #![feature(prelude_import)]
//! Docs!
#![forbid(missing_docs)]
#[prelude_import]
use std::prelude::rust_2021::*;
#[macro_use]
extern crate std;
use exporter_crate::wrapper;
/// Docs!
pub struct Wrapper<T> {
inner: T,
}
#[allow(explicit_outlives_requirements)]
#[allow(single_use_lifetimes)]
#[allow(clippy::unknown_clippy_lints)]
#[allow(clippy::redundant_pub_crate)]
#[allow(clippy::used_underscore_binding)]
const _: () = {
#[allow(dead_code)]
#[allow(single_use_lifetimes)]
#[allow(clippy::unknown_clippy_lints)]
#[allow(clippy::mut_mut)]
#[allow(clippy::redundant_pub_crate)]
#[allow(clippy::ref_option_ref)]
#[allow(clippy::type_repetition_in_bounds)]
pub struct Projection<'__pin, T>
where
Wrapper<T>: '__pin,
{
inner: ::pin_project_lite::__private::Pin<&'__pin mut (T)>,
}
#[allow(dead_code)]
#[allow(single_use_lifetimes)]
#[allow(clippy::unknown_clippy_lints)]
#[allow(clippy::mut_mut)]
#[allow(clippy::redundant_pub_crate)]
#[allow(clippy::ref_option_ref)]
#[allow(clippy::type_repetition_in_bounds)]
pub struct ProjectionRef<'__pin, T>
where
Wrapper<T>: '__pin,
{
inner: ::pin_project_lite::__private::Pin<&'__pin (T)>,
}
impl<T> Wrapper<T> {
#[inline]
pub fn project<'__pin>(
self: ::pin_project_lite::__private::Pin<&'__pin mut Self>,
) -> Projection<'__pin, T> {
unsafe {
let Self { inner } = self.get_unchecked_mut();
Projection {
inner: ::pin_project_lite::__private::Pin::new_unchecked(inner),
}
}
}
#[inline]
pub fn project_ref<'__pin>(
self: ::pin_project_lite::__private::Pin<&'__pin Self>,
) -> ProjectionRef<'__pin, T> {
unsafe {
let Self { inner } = self.get_ref();
ProjectionRef {
inner: ::pin_project_lite::__private::Pin::new_unchecked(inner),
}
}
}
}
#[allow(non_snake_case)]
pub struct __Origin<'__pin, T> {
__dummy_lifetime: ::pin_project_lite::__private::PhantomData<&'__pin ()>,
inner: T,
}
impl<'__pin, T> ::pin_project_lite::__private::Unpin for Wrapper<T>
where
__Origin<'__pin, T>: ::pin_project_lite::__private::Unpin,
{}
trait MustNotImplDrop {}
#[allow(clippy::drop_bounds, drop_bounds)]
impl<T: ::pin_project_lite::__private::Drop> MustNotImplDrop for T {}
impl<T> MustNotImplDrop for Wrapper<T> {}
#[forbid(unaligned_references, safe_packed_borrows)]
fn __assert_not_repr_packed<T>(this: &Wrapper<T>) {
let _ = &this.inner;
}
}; |
The main problem here is these two:
Then:
In the short term, I will adopt the last one to mitigate the problems (address the second problem), and in the medium term, I plan to fix it with #79 or another way. |
Finally tracked down the source of smol-rs/event-listener#61. If another macro is used to call
pin_project!
,pub
will sometimes not be properly matched bypin_project!
, and apub
projection method will be emitted.See here for my full reproduction, but the gist of the issue is as follows:
Crate #1:
Crate #2:
Result of running
cargo build
:...along with a handful of other errors complaining about missing docs on other things isolated to the
pin_project_lite
constant.This smells like a
rustc
bug to me, as this issue doesn't crop up when the import goes across modules instead of across crates.The text was updated successfully, but these errors were encountered: