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§
source§impl 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§
source§impl Binary for Protection
impl Binary for Protection
source§impl BitAnd<Protection> for Protection
impl BitAnd<Protection> for Protection
source§impl BitAndAssign<Protection> for Protection
impl BitAndAssign<Protection> for Protection
source§fn bitand_assign(&mut self, other: Self)
fn bitand_assign(&mut self, other: Self)
Disables all flags disabled in the set.
source§impl BitOr<Protection> for Protection
impl BitOr<Protection> for Protection
source§fn 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.source§impl BitOrAssign<Protection> for Protection
impl BitOrAssign<Protection> for Protection
source§fn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Adds the set of flags.
source§impl BitXor<Protection> for Protection
impl BitXor<Protection> for Protection
source§impl BitXorAssign<Protection> for Protection
impl BitXorAssign<Protection> for Protection
source§fn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Toggles the set of flags.
source§impl Clone for Protection
impl Clone for Protection
source§fn clone(&self) -> Protection
fn clone(&self) -> Protection
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for Protection
impl Debug for Protection
source§impl Extend<Protection> for Protection
impl Extend<Protection> for Protection
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<Protection> for Protection
impl FromIterator<Protection> for Protection
source§fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
source§impl Hash for Protection
impl Hash for Protection
source§impl LowerHex for Protection
impl LowerHex for Protection
source§impl Not for Protection
impl Not for Protection
source§impl Octal for Protection
impl Octal for Protection
source§impl Ord for Protection
impl Ord for Protection
source§fn cmp(&self, other: &Protection) -> Ordering
fn cmp(&self, other: &Protection) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
source§impl PartialEq<Protection> for Protection
impl PartialEq<Protection> for Protection
source§fn eq(&self, other: &Protection) -> bool
fn eq(&self, other: &Protection) -> bool
source§impl PartialOrd<Protection> for Protection
impl PartialOrd<Protection> for Protection
source§fn partial_cmp(&self, other: &Protection) -> Option<Ordering>
fn partial_cmp(&self, other: &Protection) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read moresource§impl Sub<Protection> for Protection
impl Sub<Protection> for Protection
source§impl SubAssign<Protection> for Protection
impl SubAssign<Protection> for Protection
source§fn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Disables all flags enabled in the set.