pub struct Access { /* private fields */ }Expand description
Windows process-related access permission flags.
Implementations§
Source§impl Access
impl Access
Sourcepub const READ_CONTROL: Self
pub const READ_CONTROL: Self
Required to read information in the security descriptor for the object, not including
the information in the SACL. To read or write the SACL, you must request the
ACCESS_SYSTEM_SECURITY access right. For more information, see SACL Access Right.
Sourcepub const WRITE_DAC: Self
pub const WRITE_DAC: Self
Required to modify the DACL in the security descriptor for the object.
Sourcepub const WRITE_OWNER: Self
pub const WRITE_OWNER: Self
Required to change the owner in the security descriptor for the object.
Sourcepub const SYNCHRONIZE: Self
pub const SYNCHRONIZE: Self
The right to use the object for synchronization. This enables a thread to wait until the object is in the signaled state.
Sourcepub const STANDARD_RIGHTS_REQUIRED: Self
pub const STANDARD_RIGHTS_REQUIRED: Self
Union of DELETE | READ_CONTROL | WRITE_DAC | WRITE_OWNER.
Sourcepub const PROCESS_TERMINATE: Self
pub const PROCESS_TERMINATE: Self
Required to terminate a process.
Sourcepub const PROCESS_CREATE_THREAD: Self
pub const PROCESS_CREATE_THREAD: Self
Required to create a thread.
pub const PROCESS_SET_SESSIONID: Self
Sourcepub const PROCESS_VM_OPERATION: Self
pub const PROCESS_VM_OPERATION: Self
Required to perform an operation on the address space of a process.
Sourcepub const PROCESS_VM_READ: Self
pub const PROCESS_VM_READ: Self
Required to read memory in a process.
Sourcepub const PROCESS_VM_WRITE: Self
pub const PROCESS_VM_WRITE: Self
Required to write to memory in a process.
Sourcepub const PROCESS_DUP_HANDLE: Self
pub const PROCESS_DUP_HANDLE: Self
Required to duplicate a handle.
Sourcepub const PROCESS_CREATE_PROCESS: Self
pub const PROCESS_CREATE_PROCESS: Self
Required to create a process.
Sourcepub const PROCESS_SET_QUOTA: Self
pub const PROCESS_SET_QUOTA: Self
Required to set memory limits.
Sourcepub const PROCESS_SET_INFORMATION: Self
pub const PROCESS_SET_INFORMATION: Self
Required to set certain information about a process, such as its priority class.
Sourcepub const PROCESS_QUERY_INFORMATION: Self
pub const PROCESS_QUERY_INFORMATION: Self
Required to retrieve certain information about a process, such as its token, exit code, and priority class.
Sourcepub const PROCESS_SUSPEND_RESUME: Self
pub const PROCESS_SUSPEND_RESUME: Self
Required to suspend or resume a process.
Sourcepub const PROCESS_QUERY_LIMITED_INFORMATION: Self
pub const PROCESS_QUERY_LIMITED_INFORMATION: Self
Required to retrieve certain information about a process (exit code, priority class,job status, path).
A handle that has the PROCESS_QUERY_INFORMATION access right is
automatically granted PROCESS_QUERY_LIMITED_INFORMATION.
pub const PROCESS_SET_LIMITED_INFORMATION: Self
Sourcepub const PROCESS_ALL_ACCESS: Self
pub const PROCESS_ALL_ACCESS: Self
All possible access rights for a process object.
Sourcepub const fn from_bits(bits: u32) -> Option<Self>
pub const fn from_bits(bits: u32) -> Option<Self>
Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.
Sourcepub const fn from_bits_truncate(bits: u32) -> Self
pub const fn from_bits_truncate(bits: u32) -> Self
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
Sourcepub const unsafe fn from_bits_unchecked(bits: u32) -> Self
pub const unsafe fn from_bits_unchecked(bits: u32) -> Self
Convert from underlying bit representation, preserving all bits (even those not corresponding to a defined flag).
§Safety
The caller of the bitflags! macro can chose to allow or
disallow extra bits for their bitflags type.
The caller of from_bits_unchecked() has to ensure that
all bits correspond to a defined flag or that extra bits
are valid for this bitflags type.
Sourcepub const fn intersects(&self, other: Self) -> bool
pub const fn intersects(&self, other: Self) -> bool
Returns true if there are flags common to both self and other.
Sourcepub const fn contains(&self, other: Self) -> bool
pub const fn contains(&self, other: Self) -> bool
Returns true if all of the flags in other are contained within self.
Sourcepub fn set(&mut self, other: Self, value: bool)
pub fn set(&mut self, other: Self, value: bool)
Inserts or removes the specified flags depending on the passed value.
Sourcepub const fn intersection(self, other: Self) -> Self
pub const fn intersection(self, other: Self) -> Self
Returns the intersection between the flags in self and
other.
Specifically, the returned set contains only the flags which are
present in both self and other.
This is equivalent to using the & operator (e.g.
ops::BitAnd), as in flags & other.
Sourcepub const fn union(self, other: Self) -> Self
pub const fn union(self, other: Self) -> Self
Returns the union of between the flags in self and other.
Specifically, the returned set contains all flags which are
present in either self or other, including any which are
present in both (see Self::symmetric_difference if that
is undesirable).
This is equivalent to using the | operator (e.g.
ops::BitOr), as in flags | other.
Sourcepub const fn difference(self, other: Self) -> Self
pub const fn difference(self, other: Self) -> Self
Returns the difference between the flags in self and other.
Specifically, the returned set contains all flags present in
self, except for the ones present in other.
It is also conceptually equivalent to the “bit-clear” operation:
flags & !other (and this syntax is also supported).
This is equivalent to using the - operator (e.g.
ops::Sub), as in flags - other.
Sourcepub const fn symmetric_difference(self, other: Self) -> Self
pub const fn symmetric_difference(self, other: Self) -> Self
Returns the symmetric difference between the flags
in self and other.
Specifically, the returned set contains the flags present which
are present in self or other, but that are not present in
both. Equivalently, it contains the flags present in exactly
one of the sets self and other.
This is equivalent to using the ^ operator (e.g.
ops::BitXor), as in flags ^ other.
Sourcepub const fn complement(self) -> Self
pub const fn complement(self) -> Self
Returns the complement of this set of flags.
Specifically, the returned set contains all the flags which are
not set in self, but which are allowed for this type.
Alternatively, it can be thought of as the set difference
between Self::all() and self (e.g. Self::all() - self)
This is equivalent to using the ! operator (e.g.
ops::Not), as in !flags.
Trait Implementations§
Source§impl BitAndAssign for Access
impl BitAndAssign for Access
Source§fn bitand_assign(&mut self, other: Self)
fn bitand_assign(&mut self, other: Self)
Disables all flags disabled in the set.
Source§impl BitOrAssign for Access
impl BitOrAssign for Access
Source§fn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Adds the set of flags.
Source§impl BitXorAssign for Access
impl BitXorAssign for Access
Source§fn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Toggles the set of flags.
Source§impl Extend<Access> for Access
impl Extend<Access> for Access
Source§fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one)Source§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
extend_one)Source§impl FromIterator<Access> for Access
impl FromIterator<Access> for Access
Source§fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
Source§impl Ord for Access
impl Ord for Access
Source§impl PartialOrd for Access
impl PartialOrd for Access
Source§impl SubAssign for Access
impl SubAssign for Access
Source§fn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Disables all flags enabled in the set.