Struct region::Protection [−][src]
pub struct Protection { /* fields omitted */ }
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
impl Protection
[src]
impl Protection
[src]pub const NONE: Protection
[src]
No access allowed at all.
pub const READ: Protection
[src]
Read access; writing and/or executing data will panic.
pub const WRITE: Protection
[src]
Write access; this flag alone may not be supported on all OSs.
pub const EXECUTE: Protection
[src]
Execute access; this may not be allowed depending on DEP.
pub const READ_EXECUTE: Protection
[src]
Read and execute shorthand.
pub const READ_WRITE: Protection
[src]
Read and write shorthand.
pub const READ_WRITE_EXECUTE: Protection
[src]
Read, write and execute shorthand.
pub const WRITE_EXECUTE: Protection
[src]
Write and execute shorthand.
pub const None: Protection
[src]
Use Protection::NONE instead
No access allowed at all.
pub const Read: Protection
[src]
Use Protection::READ instead
Read access; writing and/or executing data will panic.
pub const Write: Protection
[src]
Use Protection::WRITE instead
Write access; this flag alone may not be supported on all OSs.
pub const Execute: Protection
[src]
Use Protection::EXECUTE instead
Execute access; this may not be allowed depending on DEP.
pub const ReadExecute: Protection
[src]
Use Protection::READ_EXECUTE instead
Read and execute shorthand.
pub const ReadWrite: Protection
[src]
Use Protection::READ_WRITE instead
Read and write shorthand.
pub const ReadWriteExecute: Protection
[src]
Use Protection::READ_WRITE_EXECUTE instead
Read, write and execute shorthand.
pub const WriteExecute: Protection
[src]
Use Protection::WRITE_EXECUTE instead
Write and execute shorthand.
pub const fn empty() -> Protection
[src]
Returns an empty set of flags
pub const fn all() -> Protection
[src]
Returns the set containing all flags.
pub const fn bits(&self) -> usize
[src]
Returns the raw value of the flags currently stored.
pub fn from_bits(bits: usize) -> Option<Protection>
[src]
Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.
pub const fn from_bits_truncate(bits: usize) -> Protection
[src]
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
pub const unsafe fn from_bits_unchecked(bits: usize) -> Protection
[src]
Convert from underlying bit representation, preserving all bits (even those not corresponding to a defined flag).
pub const fn is_empty(&self) -> bool
[src]
Returns true
if no flags are currently stored.
pub const fn is_all(&self) -> bool
[src]
Returns true
if all flags are currently set.
pub const fn intersects(&self, other: Protection) -> bool
[src]
Returns true
if there are flags common to both self
and other
.
pub const fn contains(&self, other: Protection) -> bool
[src]
Returns true
all of the flags in other
are contained within self
.
pub fn insert(&mut self, other: Protection)
[src]
Inserts the specified flags in-place.
pub fn remove(&mut self, other: Protection)
[src]
Removes the specified flags in-place.
pub fn toggle(&mut self, other: Protection)
[src]
Toggles the specified flags in-place.
pub fn set(&mut self, other: Protection, value: bool)
[src]
Inserts or removes the specified flags depending on the passed value.
Trait Implementations
impl BitAnd<Protection> for Protection
[src]
impl BitAnd<Protection> for Protection
[src]type Output = Protection
The resulting type after applying the &
operator.
fn bitand(self, other: Protection) -> Protection
[src]
Returns the intersection between the two sets of flags.
impl BitAndAssign<Protection> for Protection
[src]
impl BitAndAssign<Protection> for Protection
[src]fn bitand_assign(&mut self, other: Protection)
[src]
Disables all flags disabled in the set.
impl BitOr<Protection> for Protection
[src]
impl BitOr<Protection> for Protection
[src]type Output = Protection
The resulting type after applying the |
operator.
fn bitor(self, other: Protection) -> Protection
[src]
Returns the union of the two sets of flags.
impl BitOrAssign<Protection> for Protection
[src]
impl BitOrAssign<Protection> for Protection
[src]fn bitor_assign(&mut self, other: Protection)
[src]
Adds the set of flags.
impl BitXor<Protection> for Protection
[src]
impl BitXor<Protection> for Protection
[src]type Output = Protection
The resulting type after applying the ^
operator.
fn bitxor(self, other: Protection) -> Protection
[src]
Returns the left flags, but with all the right flags toggled.
impl BitXorAssign<Protection> for Protection
[src]
impl BitXorAssign<Protection> for Protection
[src]fn bitxor_assign(&mut self, other: Protection)
[src]
Toggles the set of flags.
impl Clone for Protection
[src]
impl Clone for Protection
[src]fn clone(&self) -> Protection
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl Extend<Protection> for Protection
[src]
impl Extend<Protection> for Protection
[src]fn extend<T: IntoIterator<Item = Protection>>(&mut self, iterator: T)
[src]
pub fn extend_one(&mut self, item: A)
[src]
pub fn extend_reserve(&mut self, additional: usize)
[src]
impl FromIterator<Protection> for Protection
[src]
impl FromIterator<Protection> for Protection
[src]fn from_iter<T: IntoIterator<Item = Protection>>(iterator: T) -> Protection
[src]
impl Hash for Protection
[src]
impl Hash for Protection
[src]impl Not for Protection
[src]
impl Not for Protection
[src]type Output = Protection
The resulting type after applying the !
operator.
fn not(self) -> Protection
[src]
Returns the complement of this set of flags.
impl Ord for Protection
[src]
impl Ord for Protection
[src]impl PartialEq<Protection> for Protection
[src]
impl PartialEq<Protection> for Protection
[src]fn eq(&self, other: &Protection) -> bool
[src]
fn ne(&self, other: &Protection) -> bool
[src]
impl PartialOrd<Protection> for Protection
[src]
impl PartialOrd<Protection> for Protection
[src]impl Sub<Protection> for Protection
[src]
impl Sub<Protection> for Protection
[src]type Output = Protection
The resulting type after applying the -
operator.
fn sub(self, other: Protection) -> Protection
[src]
Returns the set difference of the two sets of flags.
impl SubAssign<Protection> for Protection
[src]
impl SubAssign<Protection> for Protection
[src]fn sub_assign(&mut self, other: Protection)
[src]
Disables all flags enabled in the set.