Struct region::Protection
source · [−]pub struct Protection { /* private fields */ }Expand description
Memory page protection constants.
Determines the access rights for a specific page and/or region. Some combination of flags may not work depending on the OS (e.g macOS enforces pages to be readable).
Examples
use region::Protection;
let combine = Protection::READ | Protection::WRITE;
let shorthand = Protection::READ_WRITE;Implementations
sourceimpl Protection
impl Protection
sourcepub const READ_EXECUTE: Self = _
pub const READ_EXECUTE: Self = _
Read and execute shorthand.
sourcepub const READ_WRITE: Self = _
pub const READ_WRITE: Self = _
Read and write shorthand.
sourcepub const READ_WRITE_EXECUTE: Self = _
pub const READ_WRITE_EXECUTE: Self = _
Read, write and execute shorthand.
sourcepub const WRITE_EXECUTE: Self = _
pub const WRITE_EXECUTE: Self = _
Write and execute shorthand.
sourcepub const None: Self = _
👎Deprecated since 2.2.0: Use Protection::NONE instead
pub const None: Self = _
No access allowed at all.
sourcepub const Read: Self = _
👎Deprecated since 2.2.0: Use Protection::READ instead
pub const Read: Self = _
Read access; writing and/or executing data will panic.
sourcepub const Write: Self = _
👎Deprecated since 2.2.0: Use Protection::WRITE instead
pub const Write: Self = _
Write access; this flag alone may not be supported on all OSs.
sourcepub const Execute: Self = _
👎Deprecated since 2.2.0: Use Protection::EXECUTE instead
pub const Execute: Self = _
Execute access; this may not be allowed depending on DEP.
sourcepub const ReadExecute: Self = _
👎Deprecated since 2.2.0: Use Protection::READ_EXECUTE instead
pub const ReadExecute: Self = _
Read and execute shorthand.
sourcepub const ReadWrite: Self = _
👎Deprecated since 2.2.0: Use Protection::READ_WRITE instead
pub const ReadWrite: Self = _
Read and write shorthand.
sourcepub const ReadWriteExecute: Self = _
👎Deprecated since 2.2.0: Use Protection::READ_WRITE_EXECUTE instead
pub const ReadWriteExecute: Self = _
Read, write and execute shorthand.
sourcepub const WriteExecute: Self = _
👎Deprecated since 2.2.0: Use Protection::WRITE_EXECUTE instead
pub const WriteExecute: Self = _
Write and execute shorthand.
sourcepub const fn from_bits(bits: usize) -> Option<Self>
pub const fn from_bits(bits: usize) -> 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: usize) -> Self
pub const fn from_bits_truncate(bits: usize) -> Self
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
sourcepub const unsafe fn from_bits_unchecked(bits: usize) -> Self
pub const unsafe fn from_bits_unchecked(bits: usize) -> 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
sourceimpl Binary for Protection
impl Binary for Protection
sourceimpl BitAnd<Protection> for Protection
impl BitAnd<Protection> for Protection
type Output = Protection
type Output = Protection
& operator.sourceimpl BitAndAssign<Protection> for Protection
impl BitAndAssign<Protection> for Protection
sourcefn bitand_assign(&mut self, other: Self)
fn bitand_assign(&mut self, other: Self)
Disables all flags disabled in the set.
sourceimpl BitOr<Protection> for Protection
impl BitOr<Protection> for Protection
sourcefn bitor(self, other: Protection) -> Self
fn bitor(self, other: Protection) -> Self
Returns the union of the two sets of flags.
type Output = Protection
type Output = Protection
| operator.sourceimpl BitOrAssign<Protection> for Protection
impl BitOrAssign<Protection> for Protection
sourcefn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Adds the set of flags.
sourceimpl BitXor<Protection> for Protection
impl BitXor<Protection> for Protection
sourcefn bitxor(self, other: Self) -> Self
fn bitxor(self, other: Self) -> Self
Returns the left flags, but with all the right flags toggled.
type Output = Protection
type Output = Protection
^ operator.sourceimpl BitXorAssign<Protection> for Protection
impl BitXorAssign<Protection> for Protection
sourcefn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Toggles the set of flags.
sourceimpl Clone for Protection
impl Clone for Protection
sourcefn clone(&self) -> Protection
fn clone(&self) -> Protection
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moresourceimpl Debug for Protection
impl Debug for Protection
sourceimpl Extend<Protection> for Protection
impl Extend<Protection> for Protection
sourcefn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
sourcefn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one)sourcefn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
extend_one)sourceimpl FromIterator<Protection> for Protection
impl FromIterator<Protection> for Protection
sourcefn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
sourceimpl Hash for Protection
impl Hash for Protection
sourceimpl LowerHex for Protection
impl LowerHex for Protection
sourceimpl Not for Protection
impl Not for Protection
type Output = Protection
type Output = Protection
! operator.sourceimpl Octal for Protection
impl Octal for Protection
sourceimpl Ord for Protection
impl Ord for Protection
sourcefn cmp(&self, other: &Protection) -> Ordering
fn cmp(&self, other: &Protection) -> Ordering
1.21.0 · sourcefn max(self, other: Self) -> Self
fn max(self, other: Self) -> Self
1.21.0 · sourcefn min(self, other: Self) -> Self
fn min(self, other: Self) -> Self
1.50.0 · sourcefn clamp(self, min: Self, max: Self) -> Selfwhere
Self: PartialOrd<Self>,
fn clamp(self, min: Self, max: Self) -> Selfwhere
Self: PartialOrd<Self>,
sourceimpl PartialEq<Protection> for Protection
impl PartialEq<Protection> for Protection
sourcefn eq(&self, other: &Protection) -> bool
fn eq(&self, other: &Protection) -> bool
sourceimpl PartialOrd<Protection> for Protection
impl PartialOrd<Protection> for Protection
sourcefn partial_cmp(&self, other: &Protection) -> Option<Ordering>
fn partial_cmp(&self, other: &Protection) -> Option<Ordering>
1.0.0 · sourcefn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self and other) and is used by the <=
operator. Read moresourceimpl Sub<Protection> for Protection
impl Sub<Protection> for Protection
type Output = Protection
type Output = Protection
- operator.sourceimpl SubAssign<Protection> for Protection
impl SubAssign<Protection> for Protection
sourcefn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Disables all flags enabled in the set.