QueryDirectoryFlags

Struct QueryDirectoryFlags 

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

Flags indicating how the query directory operation must be processed.

These flags control the behavior of directory enumeration, such as whether to restart the scan from the beginning or return only a single entry.

Reference: MS-SMB2 section 2.2.33

Implementations§

Source§

impl QueryDirectoryFlags

Source

pub const fn new() -> Self

Returns an instance with zero initialized data.

Source§

impl QueryDirectoryFlags

Source

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

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; 1]) -> Self

Converts the given bytes directly into the bitfield struct.

Source§

impl QueryDirectoryFlags

Source

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

Returns the value of restart_scans. The server is requested to restart the enumeration from the beginning.

Source

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

Returns the value of restart_scans.

#Errors

If the returned value contains an invalid bit pattern for restart_scans. The server is requested to restart the enumeration from the beginning.

Source

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

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

#Panics

If the given value is out of bounds for restart_scans. The server is requested to restart the enumeration from the beginning.

Source

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

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

#Errors

If the given value is out of bounds for restart_scans. The server is requested to restart the enumeration from the beginning.

Source

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

Sets the value of restart_scans to the given value.

#Panics

If the given value is out of bounds for restart_scans. The server is requested to restart the enumeration from the beginning.

Source

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

Sets the value of restart_scans to the given value.

#Errors

If the given value is out of bounds for restart_scans. The server is requested to restart the enumeration from the beginning.

Source

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

Returns the value of return_single_entry. The server is requested to only return the first entry of the search results.

Source

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

Returns the value of return_single_entry.

#Errors

If the returned value contains an invalid bit pattern for return_single_entry. The server is requested to only return the first entry of the search results.

Source

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

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

#Panics

If the given value is out of bounds for return_single_entry. The server is requested to only return the first entry of the search results.

Source

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

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

#Errors

If the given value is out of bounds for return_single_entry. The server is requested to only return the first entry of the search results.

Source

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

Sets the value of return_single_entry to the given value.

#Panics

If the given value is out of bounds for return_single_entry. The server is requested to only return the first entry of the search results.

Source

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

Sets the value of return_single_entry to the given value.

#Errors

If the given value is out of bounds for return_single_entry. The server is requested to only return the first entry of the search results.

Source

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

Returns the value of index_specified. The server is requested to return entries beginning at the byte number specified by FileIndex.

Source

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

Returns the value of index_specified.

#Errors

If the returned value contains an invalid bit pattern for index_specified. The server is requested to return entries beginning at the byte number specified by FileIndex.

Source

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

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

#Panics

If the given value is out of bounds for index_specified. The server is requested to return entries beginning at the byte number specified by FileIndex.

Source

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

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

#Errors

If the given value is out of bounds for index_specified. The server is requested to return entries beginning at the byte number specified by FileIndex.

Source

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

Sets the value of index_specified to the given value.

#Panics

If the given value is out of bounds for index_specified. The server is requested to return entries beginning at the byte number specified by FileIndex.

Source

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

Sets the value of index_specified to the given value.

#Errors

If the given value is out of bounds for index_specified. The server is requested to return entries beginning at the byte number specified by FileIndex.

Source

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

Returns the value of reopen. The server is requested to restart the enumeration from the beginning, and the search pattern is to be changed.

Source

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

Returns the value of reopen.

#Errors

If the returned value contains an invalid bit pattern for reopen. The server is requested to restart the enumeration from the beginning, and the search pattern is to be changed.

Source

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

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

#Panics

If the given value is out of bounds for reopen. The server is requested to restart the enumeration from the beginning, and the search pattern is to be changed.

Source

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

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

#Errors

If the given value is out of bounds for reopen. The server is requested to restart the enumeration from the beginning, and the search pattern is to be changed.

Source

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

Sets the value of reopen to the given value.

#Panics

If the given value is out of bounds for reopen. The server is requested to restart the enumeration from the beginning, and the search pattern is to be changed.

Source

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

Sets the value of reopen to the given value.

#Errors

If the given value is out of bounds for reopen. The server is requested to restart the enumeration from the beginning, and the search pattern is to be changed.

Trait Implementations§

Source§

impl BinRead for QueryDirectoryFlags

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 QueryDirectoryFlags

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 QueryDirectoryFlags

Source§

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

Source§

impl Clone for QueryDirectoryFlags

Source§

fn clone(&self) -> QueryDirectoryFlags

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 QueryDirectoryFlags

Source§

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

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

impl Default for QueryDirectoryFlags

Source§

fn default() -> QueryDirectoryFlags

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

impl PartialEq for QueryDirectoryFlags

Source§

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

Source§

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

The endianness of the type.
Source§

impl WriteEndian for QueryDirectoryFlags

Source§

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

The endianness of the type.
Source§

impl Copy for QueryDirectoryFlags

Source§

impl Eq for QueryDirectoryFlags

Source§

impl StructuralPartialEq for QueryDirectoryFlags

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