Path: blob/master/rust/pin-init/internal/src/pinned_drop.rs
50683 views
// SPDX-License-Identifier: Apache-2.0 OR MIT12use proc_macro2::TokenStream;3use quote::quote;4use syn::{parse::Nothing, parse_quote, spanned::Spanned, ImplItem, ItemImpl, Token};56use crate::diagnostics::{DiagCtxt, ErrorGuaranteed};78pub(crate) fn pinned_drop(9_args: Nothing,10mut input: ItemImpl,11dcx: &mut DiagCtxt,12) -> Result<TokenStream, ErrorGuaranteed> {13if let Some(unsafety) = input.unsafety {14dcx.error(unsafety, "implementing `PinnedDrop` is safe");15}16input.unsafety = Some(Token);17match &mut input.trait_ {18Some((not, path, _for)) => {19if let Some(not) = not {20dcx.error(not, "cannot implement `!PinnedDrop`");21}22for (seg, expected) in path23.segments24.iter()25.rev()26.zip(["PinnedDrop", "pin_init", ""])27{28if expected.is_empty() || seg.ident != expected {29dcx.error(seg, "bad import path for `PinnedDrop`");30}31if !seg.arguments.is_none() {32dcx.error(&seg.arguments, "unexpected arguments for `PinnedDrop` path");33}34}35*path = parse_quote!(::pin_init::PinnedDrop);36}37None => {38let span = input39.impl_token40.span41.join(input.self_ty.span())42.unwrap_or(input.impl_token.span);43dcx.error(44span,45"expected `impl ... PinnedDrop for ...`, got inherent impl",46);47}48}49for item in &mut input.items {50if let ImplItem::Fn(fn_item) = item {51if fn_item.sig.ident == "drop" {52fn_item53.sig54.inputs55.push(parse_quote!(_: ::pin_init::__internal::OnlyCallFromDrop));56}57}58}59Ok(quote!(#input))60}616263