syn

Enum BinOp

Source
#[non_exhaustive]
pub enum BinOp {
Show 28 variants Add(Plus), Sub(Minus), Mul(Star), Div(Slash), Rem(Percent), And(AndAnd), Or(OrOr), BitXor(Caret), BitAnd(And), BitOr(Or), Shl(Shl), Shr(Shr), Eq(EqEq), Lt(Lt), Le(Le), Ne(Ne), Ge(Ge), Gt(Gt), AddAssign(PlusEq), SubAssign(MinusEq), MulAssign(StarEq), DivAssign(SlashEq), RemAssign(PercentEq), BitXorAssign(CaretEq), BitAndAssign(AndEq), BitOrAssign(OrEq), ShlAssign(ShlEq), ShrAssign(ShrEq),
}
Available on crate features full or derive only.
Expand description

A binary operator: +, +=, &.

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

Add(Plus)

The + operator (addition)

§

Sub(Minus)

The - operator (subtraction)

§

Mul(Star)

The * operator (multiplication)

§

Div(Slash)

The / operator (division)

§

Rem(Percent)

The % operator (modulus)

§

And(AndAnd)

The && operator (logical and)

§

Or(OrOr)

The || operator (logical or)

§

BitXor(Caret)

The ^ operator (bitwise xor)

§

BitAnd(And)

The & operator (bitwise and)

§

BitOr(Or)

The | operator (bitwise or)

§

Shl(Shl)

The << operator (shift left)

§

Shr(Shr)

The >> operator (shift right)

§

Eq(EqEq)

The == operator (equality)

§

Lt(Lt)

The < operator (less than)

§

Le(Le)

The <= operator (less than or equal to)

§

Ne(Ne)

The != operator (not equal to)

§

Ge(Ge)

The >= operator (greater than or equal to)

§

Gt(Gt)

The > operator (greater than)

§

AddAssign(PlusEq)

The += operator

§

SubAssign(MinusEq)

The -= operator

§

MulAssign(StarEq)

The *= operator

§

DivAssign(SlashEq)

The /= operator

§

RemAssign(PercentEq)

The %= operator

§

BitXorAssign(CaretEq)

The ^= operator

§

BitAndAssign(AndEq)

The &= operator

§

BitOrAssign(OrEq)

The |= operator

§

ShlAssign(ShlEq)

The <<= operator

§

ShrAssign(ShrEq)

The >>= operator

Trait Implementations§

Source§

impl Clone for BinOp

Available on crate feature clone-impls only.
Source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for BinOp

Available on crate feature extra-traits only.
Source§

fn fmt(&self, formatter: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Hash for BinOp

Available on crate feature extra-traits only.
Source§

fn hash<H>(&self, state: &mut H)
where H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Parse for BinOp

Available on crate feature parsing only.
Source§

fn parse(input: ParseStream<'_>) -> Result<Self>

Source§

impl PartialEq for BinOp

Available on crate feature extra-traits only.
Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl ToTokens for BinOp

Available on crate feature printing only.
Source§

fn to_tokens(&self, tokens: &mut TokenStream)

Write self to the given TokenStream. Read more
Source§

fn to_token_stream(&self) -> TokenStream

Convert self directly into a TokenStream object. Read more
Source§

fn into_token_stream(self) -> TokenStream
where Self: Sized,

Convert self directly into a TokenStream object. Read more
Source§

impl Copy for BinOp

Available on crate feature clone-impls only.
Source§

impl Eq for BinOp

Available on crate feature extra-traits only.

Auto Trait Implementations§

§

impl Freeze for BinOp

§

impl RefUnwindSafe for BinOp

§

impl !Send for BinOp

§

impl !Sync for BinOp

§

impl Unpin for BinOp

§

impl UnwindSafe for BinOp

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Spanned for T
where T: Spanned + ?Sized,

Source§

fn span(&self) -> Span

Available on crate features parsing and printing only.
Returns a Span covering the complete contents of this syntax tree node, or Span::call_site() if this node is empty.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.