pub enum PluginOp {
Keep(usize),
Modify(usize, DirectiveWrapper),
Insert(DirectiveWrapper),
Delete(usize),
}Expand description
One operation in a PluginOutput’s ordered op list.
Ops describe how each output directive relates to the input:
PluginOp::Keep— reuseinput[i]unchanged. Span andfile_idpreserved.PluginOp::Modify— output a new wrapper, but inheritinput[i]’s source identity (span /file_id). Plugins use this when transforming an existing directive’s content (e.g., adding tags) so error reporting still points at the original source location.PluginOp::Insert— emit a fresh directive with synthesized source location (SYNTHESIZED_FILE_ID, zero span). Use for directives the plugin invents from scratch.PluginOp::Delete— dropinput[i]. Must be explicit; omitting an index withoutDeleteis a protocol violation that the host reports as a plugin error.
Variants§
Keep(usize)
Reuse input[i] unchanged (preserves original span + file_id).
Modify(usize, DirectiveWrapper)
Replace input[i]’s content with wrapper, but inherit
input[i]’s source identity (span + file_id).
Insert(DirectiveWrapper)
Insert a fresh directive with synthesized source location.
Delete(usize)
Drop input[i]. Must be explicit — see type-level docs.
Trait Implementations§
Source§impl<'de> Deserialize<'de> for PluginOp
impl<'de> Deserialize<'de> for PluginOp
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<PluginOp, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<PluginOp, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl Serialize for PluginOp
impl Serialize for PluginOp
Source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
Auto Trait Implementations§
impl Freeze for PluginOp
impl RefUnwindSafe for PluginOp
impl Send for PluginOp
impl Sync for PluginOp
impl Unpin for PluginOp
impl UnsafeUnpin for PluginOp
impl UnwindSafe for PluginOp
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.