HeaderFlags

Struct HeaderFlags 

Source
pub struct HeaderFlags { /* private fields */ }
Expand description

SMB2 header flags.

Indicates how to process the operation.

Reference: MS-SMB2 2.2.1.2

Implementations§

Source§

impl HeaderFlags

Source

pub const fn new() -> Self

Returns an instance with zero initialized data.

Source§

impl HeaderFlags

Source

pub const fn into_bytes(self) -> [u8; 4]

Returns the underlying bits.

§Layout

The returned byte array is layed out in the same way as described here.

Source

pub const fn from_bytes(bytes: [u8; 4]) -> Self

Converts the given bytes directly into the bitfield struct.

Source§

impl HeaderFlags

Source

pub fn server_to_redir(&self) -> <bool as Specifier>::InOut

Returns the value of server_to_redir. Message is a server response (set in responses).

Source

pub fn server_to_redir_or_err( &self, ) -> Result<<bool as Specifier>::InOut, InvalidBitPattern<<bool as Specifier>::Bytes>>

Returns the value of server_to_redir.

#Errors

If the returned value contains an invalid bit pattern for server_to_redir. Message is a server response (set in responses).

Source

pub fn with_server_to_redir(self, new_val: <bool as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of server_to_redir set to the given value.

#Panics

If the given value is out of bounds for server_to_redir. Message is a server response (set in responses).

Source

pub fn with_server_to_redir_checked( self, new_val: <bool as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of server_to_redir set to the given value.

#Errors

If the given value is out of bounds for server_to_redir. Message is a server response (set in responses).

Source

pub fn set_server_to_redir(&mut self, new_val: <bool as Specifier>::InOut)

Sets the value of server_to_redir to the given value.

#Panics

If the given value is out of bounds for server_to_redir. Message is a server response (set in responses).

Source

pub fn set_server_to_redir_checked( &mut self, new_val: <bool as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of server_to_redir to the given value.

#Errors

If the given value is out of bounds for server_to_redir. Message is a server response (set in responses).

Source

pub fn async_command(&self) -> <bool as Specifier>::InOut

Returns the value of async_command. Message is part of an asynchronous operation.

Source

pub fn async_command_or_err( &self, ) -> Result<<bool as Specifier>::InOut, InvalidBitPattern<<bool as Specifier>::Bytes>>

Returns the value of async_command.

#Errors

If the returned value contains an invalid bit pattern for async_command. Message is part of an asynchronous operation.

Source

pub fn with_async_command(self, new_val: <bool as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of async_command set to the given value.

#Panics

If the given value is out of bounds for async_command. Message is part of an asynchronous operation.

Source

pub fn with_async_command_checked( self, new_val: <bool as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of async_command set to the given value.

#Errors

If the given value is out of bounds for async_command. Message is part of an asynchronous operation.

Source

pub fn set_async_command(&mut self, new_val: <bool as Specifier>::InOut)

Sets the value of async_command to the given value.

#Panics

If the given value is out of bounds for async_command. Message is part of an asynchronous operation.

Source

pub fn set_async_command_checked( &mut self, new_val: <bool as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of async_command to the given value.

#Errors

If the given value is out of bounds for async_command. Message is part of an asynchronous operation.

Source

pub fn related_operations(&self) -> <bool as Specifier>::InOut

Returns the value of related_operations. Request is a related operation in a compounded chain.

Source

pub fn related_operations_or_err( &self, ) -> Result<<bool as Specifier>::InOut, InvalidBitPattern<<bool as Specifier>::Bytes>>

Returns the value of related_operations.

#Errors

If the returned value contains an invalid bit pattern for related_operations. Request is a related operation in a compounded chain.

Returns a copy of the bitfield with the value of related_operations set to the given value.

#Panics

If the given value is out of bounds for related_operations. Request is a related operation in a compounded chain.

Returns a copy of the bitfield with the value of related_operations set to the given value.

#Errors

If the given value is out of bounds for related_operations. Request is a related operation in a compounded chain.

Sets the value of related_operations to the given value.

#Panics

If the given value is out of bounds for related_operations. Request is a related operation in a compounded chain.

Sets the value of related_operations to the given value.

#Errors

If the given value is out of bounds for related_operations. Request is a related operation in a compounded chain.

Source

pub fn signed(&self) -> <bool as Specifier>::InOut

Returns the value of signed. Message is signed.

Source

pub fn signed_or_err( &self, ) -> Result<<bool as Specifier>::InOut, InvalidBitPattern<<bool as Specifier>::Bytes>>

Returns the value of signed.

#Errors

If the returned value contains an invalid bit pattern for signed. Message is signed.

Source

pub fn with_signed(self, new_val: <bool as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of signed set to the given value.

#Panics

If the given value is out of bounds for signed. Message is signed.

Source

pub fn with_signed_checked( self, new_val: <bool as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of signed set to the given value.

#Errors

If the given value is out of bounds for signed. Message is signed.

Source

pub fn set_signed(&mut self, new_val: <bool as Specifier>::InOut)

Sets the value of signed to the given value.

#Panics

If the given value is out of bounds for signed. Message is signed.

Source

pub fn set_signed_checked( &mut self, new_val: <bool as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of signed to the given value.

#Errors

If the given value is out of bounds for signed. Message is signed.

Source

pub fn priority_mask(&self) -> <B3 as Specifier>::InOut

Returns the value of priority_mask. Priority mask for quality of service.

Source

pub fn priority_mask_or_err( &self, ) -> Result<<B3 as Specifier>::InOut, InvalidBitPattern<<B3 as Specifier>::Bytes>>

Returns the value of priority_mask.

#Errors

If the returned value contains an invalid bit pattern for priority_mask. Priority mask for quality of service.

Source

pub fn with_priority_mask(self, new_val: <B3 as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of priority_mask set to the given value.

#Panics

If the given value is out of bounds for priority_mask. Priority mask for quality of service.

Source

pub fn with_priority_mask_checked( self, new_val: <B3 as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of priority_mask set to the given value.

#Errors

If the given value is out of bounds for priority_mask. Priority mask for quality of service.

Source

pub fn set_priority_mask(&mut self, new_val: <B3 as Specifier>::InOut)

Sets the value of priority_mask to the given value.

#Panics

If the given value is out of bounds for priority_mask. Priority mask for quality of service.

Source

pub fn set_priority_mask_checked( &mut self, new_val: <B3 as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of priority_mask to the given value.

#Errors

If the given value is out of bounds for priority_mask. Priority mask for quality of service.

Source

pub fn dfs_operation(&self) -> <bool as Specifier>::InOut

Returns the value of dfs_operation. Request is a DFS operation.

Source

pub fn dfs_operation_or_err( &self, ) -> Result<<bool as Specifier>::InOut, InvalidBitPattern<<bool as Specifier>::Bytes>>

Returns the value of dfs_operation.

#Errors

If the returned value contains an invalid bit pattern for dfs_operation. Request is a DFS operation.

Source

pub fn with_dfs_operation(self, new_val: <bool as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of dfs_operation set to the given value.

#Panics

If the given value is out of bounds for dfs_operation. Request is a DFS operation.

Source

pub fn with_dfs_operation_checked( self, new_val: <bool as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of dfs_operation set to the given value.

#Errors

If the given value is out of bounds for dfs_operation. Request is a DFS operation.

Source

pub fn set_dfs_operation(&mut self, new_val: <bool as Specifier>::InOut)

Sets the value of dfs_operation to the given value.

#Panics

If the given value is out of bounds for dfs_operation. Request is a DFS operation.

Source

pub fn set_dfs_operation_checked( &mut self, new_val: <bool as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of dfs_operation to the given value.

#Errors

If the given value is out of bounds for dfs_operation. Request is a DFS operation.

Source

pub fn replay_operation(&self) -> <bool as Specifier>::InOut

Returns the value of replay_operation. Request is a replay operation for resilient handles.

Source

pub fn replay_operation_or_err( &self, ) -> Result<<bool as Specifier>::InOut, InvalidBitPattern<<bool as Specifier>::Bytes>>

Returns the value of replay_operation.

#Errors

If the returned value contains an invalid bit pattern for replay_operation. Request is a replay operation for resilient handles.

Source

pub fn with_replay_operation(self, new_val: <bool as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of replay_operation set to the given value.

#Panics

If the given value is out of bounds for replay_operation. Request is a replay operation for resilient handles.

Source

pub fn with_replay_operation_checked( self, new_val: <bool as Specifier>::InOut, ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of replay_operation set to the given value.

#Errors

If the given value is out of bounds for replay_operation. Request is a replay operation for resilient handles.

Source

pub fn set_replay_operation(&mut self, new_val: <bool as Specifier>::InOut)

Sets the value of replay_operation to the given value.

#Panics

If the given value is out of bounds for replay_operation. Request is a replay operation for resilient handles.

Source

pub fn set_replay_operation_checked( &mut self, new_val: <bool as Specifier>::InOut, ) -> Result<(), OutOfBounds>

Sets the value of replay_operation to the given value.

#Errors

If the given value is out of bounds for replay_operation. Request is a replay operation for resilient handles.

Trait Implementations§

Source§

impl BinRead for HeaderFlags

Source§

type Args<'__binrw_generated_args_lifetime> = ()

The type used for the args parameter of read_args() and read_options(). Read more
Source§

fn read_options<R: Read + Seek>( __binrw_generated_var_reader: &mut R, __binrw_generated_var_endian: Endian, __binrw_generated_var_arguments: Self::Args<'_>, ) -> BinResult<Self>

Read Self from the reader using the given Endian and arguments. Read more
Source§

fn read<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self: ReadEndian, Self::Args<'a>: for<'a> Required,

Read Self from the reader using default arguments. Read more
Source§

fn read_be<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read Self from the reader using default arguments and assuming big-endian byte order. Read more
Source§

fn read_le<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read Self from the reader using default arguments and assuming little-endian byte order. Read more
Source§

fn read_ne<R>(reader: &mut R) -> Result<Self, Error>
where R: Read + Seek, Self::Args<'a>: for<'a> Required,

Read T from the reader assuming native-endian byte order. Read more
Source§

fn read_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek, Self: ReadEndian,

Read Self from the reader using the given arguments. Read more
Source§

fn read_be_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read Self from the reader, assuming big-endian byte order, using the given arguments. Read more
Source§

fn read_le_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read Self from the reader, assuming little-endian byte order, using the given arguments. Read more
Source§

fn read_ne_args<R>(reader: &mut R, args: Self::Args<'_>) -> Result<Self, Error>
where R: Read + Seek,

Read T from the reader, assuming native-endian byte order, using the given arguments. Read more
Source§

impl BinWrite for HeaderFlags

Source§

type Args<'__binrw_generated_args_lifetime> = ()

The type used for the args parameter of write_args() and write_options(). Read more
Source§

fn write_options<W: Write + Seek>( &self, __binrw_generated_var_writer: &mut W, __binrw_generated_var_endian: Endian, __binrw_generated_var_arguments: Self::Args<'_>, ) -> BinResult<()>

Write Self to the writer using the given Endian and arguments. Read more
Source§

fn write<W>(&self, writer: &mut W) -> Result<(), Error>
where W: Write + Seek, Self: WriteEndian, Self::Args<'a>: for<'a> Required,

Write Self to the writer using default arguments. Read more
Source§

fn write_be<W>(&self, writer: &mut W) -> Result<(), Error>
where W: Write + Seek, Self::Args<'a>: for<'a> Required,

Write Self to the writer assuming big-endian byte order. Read more
Source§

fn write_le<W>(&self, writer: &mut W) -> Result<(), Error>
where W: Write + Seek, Self::Args<'a>: for<'a> Required,

Write Self to the writer assuming little-endian byte order. Read more
Source§

fn write_ne<W>(&self, writer: &mut W) -> Result<(), Error>
where W: Write + Seek, Self::Args<'a>: for<'a> Required,

Write Self to the writer assuming native-endian byte order. Read more
Source§

fn write_args<W>( &self, writer: &mut W, args: Self::Args<'_>, ) -> Result<(), Error>
where W: Write + Seek, Self: WriteEndian,

Write Self to the writer using the given arguments. Read more
Source§

fn write_be_args<W>( &self, writer: &mut W, args: Self::Args<'_>, ) -> Result<(), Error>
where W: Write + Seek,

Write Self to the writer, assuming big-endian byte order, using the given arguments. Read more
Source§

fn write_le_args<W>( &self, writer: &mut W, args: Self::Args<'_>, ) -> Result<(), Error>
where W: Write + Seek,

Write Self to the writer, assuming little-endian byte order, using the given arguments. Read more
Source§

fn write_ne_args<W>( &self, writer: &mut W, args: Self::Args<'_>, ) -> Result<(), Error>
where W: Write + Seek,

Write Self to the writer, assuming native-endian byte order, using the given arguments. Read more
Source§

impl CheckTotalSizeMultipleOf8 for HeaderFlags

Source§

type Size = TotalSize<[(); 0]>

Source§

impl Clone for HeaderFlags

Source§

fn clone(&self) -> HeaderFlags

Returns a duplicate 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 HeaderFlags

Source§

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

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

impl Default for HeaderFlags

Source§

fn default() -> HeaderFlags

Returns the “default value” for a type. Read more
Source§

impl PartialEq for HeaderFlags

Source§

fn eq(&self, other: &HeaderFlags) -> 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 ReadEndian for HeaderFlags

Source§

const ENDIAN: EndianKind = binrw::meta::EndianKind::None

The endianness of the type.
Source§

impl WriteEndian for HeaderFlags

Source§

const ENDIAN: EndianKind = binrw::meta::EndianKind::None

The endianness of the type.
Source§

impl Copy for HeaderFlags

Source§

impl Eq for HeaderFlags

Source§

impl StructuralPartialEq for HeaderFlags

Auto Trait Implementations§

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, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> 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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V