Rollup merge of #128925 - dingxiangfei2009:smart-ptr-helper-attr, r=compiler-errors
derive(SmartPointer): register helper attributes Fix #128888 This PR enables built-in macros to register helper attributes, if any, to support correct name resolution in the correct lexical scope under the macros. Also, `#[pointee]` is moved into the scope under `derive(SmartPointer)`. cc `@Darksonn` `@davidtwco`
This commit is contained in:
commit
9938349c71
@ -578,12 +578,6 @@ pub struct BuiltinAttribute {
|
||||
EncodeCrossCrate::No, coroutines, experimental!(coroutines)
|
||||
),
|
||||
|
||||
// `#[pointee]` attribute to designate the pointee type in SmartPointer derive-macro
|
||||
gated!(
|
||||
pointee, Normal, template!(Word), ErrorFollowing,
|
||||
EncodeCrossCrate::No, derive_smart_pointer, experimental!(pointee)
|
||||
),
|
||||
|
||||
// RFC 3543
|
||||
// `#[patchable_function_entry(prefix_nops = m, entry_nops = n)]`
|
||||
gated!(
|
||||
|
@ -1060,7 +1060,7 @@ pub trait FnPtr: Copy + Clone {
|
||||
}
|
||||
|
||||
/// Derive macro generating impls of traits related to smart pointers.
|
||||
#[rustc_builtin_macro]
|
||||
#[rustc_builtin_macro(SmartPointer, attributes(pointee))]
|
||||
#[allow_internal_unstable(dispatch_from_dyn, coerce_unsized, unsize)]
|
||||
#[unstable(feature = "derive_smart_pointer", issue = "123430")]
|
||||
pub macro SmartPointer($item:item) {
|
||||
|
45
tests/ui/deriving/auxiliary/another-proc-macro.rs
Normal file
45
tests/ui/deriving/auxiliary/another-proc-macro.rs
Normal file
@ -0,0 +1,45 @@
|
||||
//@ force-host
|
||||
//@ no-prefer-dynamic
|
||||
|
||||
#![crate_type = "proc-macro"]
|
||||
#![feature(proc_macro_quote)]
|
||||
|
||||
extern crate proc_macro;
|
||||
|
||||
use proc_macro::{quote, TokenStream};
|
||||
|
||||
#[proc_macro_derive(AnotherMacro, attributes(pointee))]
|
||||
pub fn derive(_input: TokenStream) -> TokenStream {
|
||||
quote! {
|
||||
const _: () = {
|
||||
const ANOTHER_MACRO_DERIVED: () = ();
|
||||
};
|
||||
}
|
||||
.into()
|
||||
}
|
||||
|
||||
#[proc_macro_attribute]
|
||||
pub fn pointee(
|
||||
_attr: proc_macro::TokenStream,
|
||||
_item: proc_macro::TokenStream,
|
||||
) -> proc_macro::TokenStream {
|
||||
quote! {
|
||||
const _: () = {
|
||||
const POINTEE_MACRO_ATTR_DERIVED: () = ();
|
||||
};
|
||||
}
|
||||
.into()
|
||||
}
|
||||
|
||||
#[proc_macro_attribute]
|
||||
pub fn default(
|
||||
_attr: proc_macro::TokenStream,
|
||||
_item: proc_macro::TokenStream,
|
||||
) -> proc_macro::TokenStream {
|
||||
quote! {
|
||||
const _: () = {
|
||||
const DEFAULT_MACRO_ATTR_DERIVED: () = ();
|
||||
};
|
||||
}
|
||||
.into()
|
||||
}
|
25
tests/ui/deriving/built-in-proc-macro-scope.rs
Normal file
25
tests/ui/deriving/built-in-proc-macro-scope.rs
Normal file
@ -0,0 +1,25 @@
|
||||
//@ check-pass
|
||||
//@ aux-build: another-proc-macro.rs
|
||||
//@ compile-flags: -Zunpretty=expanded
|
||||
|
||||
#![feature(derive_smart_pointer)]
|
||||
|
||||
#[macro_use]
|
||||
extern crate another_proc_macro;
|
||||
|
||||
use another_proc_macro::{pointee, AnotherMacro};
|
||||
|
||||
#[derive(core::marker::SmartPointer)]
|
||||
#[repr(transparent)]
|
||||
pub struct Ptr<'a, #[pointee] T: ?Sized> {
|
||||
data: &'a mut T,
|
||||
}
|
||||
|
||||
#[pointee]
|
||||
fn f() {}
|
||||
|
||||
#[derive(AnotherMacro)]
|
||||
#[pointee]
|
||||
struct MyStruct;
|
||||
|
||||
fn main() {}
|
43
tests/ui/deriving/built-in-proc-macro-scope.stdout
Normal file
43
tests/ui/deriving/built-in-proc-macro-scope.stdout
Normal file
@ -0,0 +1,43 @@
|
||||
#![feature(prelude_import)]
|
||||
#![no_std]
|
||||
//@ check-pass
|
||||
//@ aux-build: another-proc-macro.rs
|
||||
//@ compile-flags: -Zunpretty=expanded
|
||||
|
||||
#![feature(derive_smart_pointer)]
|
||||
#[prelude_import]
|
||||
use ::std::prelude::rust_2015::*;
|
||||
#[macro_use]
|
||||
extern crate std;
|
||||
|
||||
#[macro_use]
|
||||
extern crate another_proc_macro;
|
||||
|
||||
use another_proc_macro::{pointee, AnotherMacro};
|
||||
|
||||
#[repr(transparent)]
|
||||
pub struct Ptr<'a, #[pointee] T: ?Sized> {
|
||||
data: &'a mut T,
|
||||
}
|
||||
#[automatically_derived]
|
||||
impl<'a, T: ?Sized + ::core::marker::Unsize<__S>, __S: ?Sized>
|
||||
::core::ops::DispatchFromDyn<Ptr<'a, __S>> for Ptr<'a, T> {
|
||||
}
|
||||
#[automatically_derived]
|
||||
impl<'a, T: ?Sized + ::core::marker::Unsize<__S>, __S: ?Sized>
|
||||
::core::ops::CoerceUnsized<Ptr<'a, __S>> for Ptr<'a, T> {
|
||||
}
|
||||
|
||||
|
||||
|
||||
const _: () =
|
||||
{
|
||||
const POINTEE_MACRO_ATTR_DERIVED: () = ();
|
||||
};
|
||||
#[pointee]
|
||||
struct MyStruct;
|
||||
const _: () =
|
||||
{
|
||||
const ANOTHER_MACRO_DERIVED: () = ();
|
||||
};
|
||||
fn main() {}
|
20
tests/ui/deriving/proc-macro-attribute-mixing.rs
Normal file
20
tests/ui/deriving/proc-macro-attribute-mixing.rs
Normal file
@ -0,0 +1,20 @@
|
||||
// This test certify that we can mix attribute macros from Rust and external proc-macros.
|
||||
// For instance, `#[derive(Default)]` uses `#[default]` and `#[derive(SmartPointer)]` uses
|
||||
// `#[pointee]`.
|
||||
// The scoping rule should allow the use of the said two attributes when external proc-macros
|
||||
// are in scope.
|
||||
|
||||
//@ check-pass
|
||||
//@ aux-build: another-proc-macro.rs
|
||||
//@ compile-flags: -Zunpretty=expanded
|
||||
|
||||
#![feature(derive_smart_pointer)]
|
||||
|
||||
#[macro_use]
|
||||
extern crate another_proc_macro;
|
||||
|
||||
#[pointee]
|
||||
fn f() {}
|
||||
|
||||
#[default]
|
||||
fn g() {}
|
30
tests/ui/deriving/proc-macro-attribute-mixing.stdout
Normal file
30
tests/ui/deriving/proc-macro-attribute-mixing.stdout
Normal file
@ -0,0 +1,30 @@
|
||||
#![feature(prelude_import)]
|
||||
#![no_std]
|
||||
// This test certify that we can mix attribute macros from Rust and external proc-macros.
|
||||
// For instance, `#[derive(Default)]` uses `#[default]` and `#[derive(SmartPointer)]` uses
|
||||
// `#[pointee]`.
|
||||
// The scoping rule should allow the use of the said two attributes when external proc-macros
|
||||
// are in scope.
|
||||
|
||||
//@ check-pass
|
||||
//@ aux-build: another-proc-macro.rs
|
||||
//@ compile-flags: -Zunpretty=expanded
|
||||
|
||||
#![feature(derive_smart_pointer)]
|
||||
#[prelude_import]
|
||||
use ::std::prelude::rust_2015::*;
|
||||
#[macro_use]
|
||||
extern crate std;
|
||||
|
||||
#[macro_use]
|
||||
extern crate another_proc_macro;
|
||||
|
||||
|
||||
const _: () =
|
||||
{
|
||||
const POINTEE_MACRO_ATTR_DERIVED: () = ();
|
||||
};
|
||||
const _: () =
|
||||
{
|
||||
const DEFAULT_MACRO_ATTR_DERIVED: () = ();
|
||||
};
|
@ -3,7 +3,6 @@
|
||||
#[derive(SmartPointer)] //~ ERROR use of unstable library feature 'derive_smart_pointer'
|
||||
#[repr(transparent)]
|
||||
struct MyPointer<'a, #[pointee] T: ?Sized> {
|
||||
//~^ ERROR the `#[pointee]` attribute is an experimental feature
|
||||
ptr: &'a T,
|
||||
}
|
||||
|
||||
|
@ -8,16 +8,6 @@ LL | #[derive(SmartPointer)]
|
||||
= help: add `#![feature(derive_smart_pointer)]` to the crate attributes to enable
|
||||
= note: this compiler was built on YYYY-MM-DD; consider upgrading it if it is out of date
|
||||
|
||||
error[E0658]: the `#[pointee]` attribute is an experimental feature
|
||||
--> $DIR/feature-gate-derive-smart-pointer.rs:5:22
|
||||
|
|
||||
LL | struct MyPointer<'a, #[pointee] T: ?Sized> {
|
||||
| ^^^^^^^^^^
|
||||
|
|
||||
= note: see issue #123430 <https://github.com/rust-lang/rust/issues/123430> for more information
|
||||
= help: add `#![feature(derive_smart_pointer)]` to the crate attributes to enable
|
||||
= note: this compiler was built on YYYY-MM-DD; consider upgrading it if it is out of date
|
||||
|
||||
error[E0658]: use of unstable library feature 'derive_smart_pointer'
|
||||
--> $DIR/feature-gate-derive-smart-pointer.rs:1:5
|
||||
|
|
||||
@ -28,6 +18,6 @@ LL | use std::marker::SmartPointer;
|
||||
= help: add `#![feature(derive_smart_pointer)]` to the crate attributes to enable
|
||||
= note: this compiler was built on YYYY-MM-DD; consider upgrading it if it is out of date
|
||||
|
||||
error: aborting due to 3 previous errors
|
||||
error: aborting due to 2 previous errors
|
||||
|
||||
For more information about this error, try `rustc --explain E0658`.
|
||||
|
Loading…
Reference in New Issue
Block a user