Struct ext_php_rs::flags::ZvalTypeFlags
source · pub struct ZvalTypeFlags { /* private fields */ }
Expand description
Flags used for setting the type of Zval.
Implementations§
source§impl ZvalTypeFlags
impl ZvalTypeFlags
pub const Undef: Self = _
pub const Null: Self = _
pub const False: Self = _
pub const True: Self = _
pub const Long: Self = _
pub const Double: Self = _
pub const String: Self = _
pub const Array: Self = _
pub const Object: Self = _
pub const Resource: Self = _
pub const Reference: Self = _
pub const Callable: Self = _
pub const ConstantExpression: Self = _
pub const Void: Self = _
pub const Ptr: Self = _
pub const InternedStringEx: Self = _
pub const StringEx: Self = _
pub const ArrayEx: Self = _
pub const ObjectEx: Self = _
pub const ResourceEx: Self = _
pub const ReferenceEx: Self = _
pub const ConstantAstEx: Self = _
pub const RefCounted: Self = _
pub const Collectable: Self = _
sourcepub const fn bits(&self) -> u32
pub const fn bits(&self) -> u32
Returns the raw value of the flags currently stored.
Examples found in repository?
484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511
pub fn set_ptr<T>(&mut self, ptr: *mut T) {
self.u1.type_info = ZvalTypeFlags::Ptr.bits();
self.value.ptr = ptr as *mut c_void;
}
/// Used to drop the Zval but keep the value of the zval intact.
///
/// This is important when copying the value of the zval, as the actual
/// value will not be copied, but the pointer to the value (string for
/// example) will be copied.
pub(crate) fn release(mut self) {
// NOTE(david): don't use `change_type` here as we are wanting to keep the
// contents intact.
self.u1.type_info = ZvalTypeFlags::Null.bits();
}
/// Changes the type of the zval, freeing the current contents when
/// applicable.
///
/// # Parameters
///
/// * `ty` - The new type of the zval.
fn change_type(&mut self, ty: ZvalTypeFlags) {
// SAFETY: we have exclusive mutable access to this zval so can free the
// contents.
unsafe { zval_ptr_dtor(self) };
self.u1.type_info = ty.bits();
}
More examples
74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
unsafe fn internal<T: RegisteredClass>(
object: *mut ZendObject,
member: *mut ZendStr,
type_: c_int,
cache_slot: *mut *mut c_void,
rv: *mut Zval,
) -> PhpResult<*mut Zval> {
let obj = object
.as_mut()
.and_then(|obj| ZendClassObject::<T>::from_zend_obj_mut(obj))
.ok_or("Invalid object pointer given")?;
let prop_name = member
.as_ref()
.ok_or("Invalid property name pointer given")?;
let self_ = &mut **obj;
let props = T::get_metadata().get_properties();
let prop = props.get(prop_name.as_str()?);
// retval needs to be treated as initialized, so we set the type to null
let rv_mut = rv.as_mut().ok_or("Invalid return zval given")?;
rv_mut.u1.type_info = ZvalTypeFlags::Null.bits();
Ok(match prop {
Some(prop) => {
prop.get(self_, rv_mut)?;
rv
}
None => zend_std_read_property(object, member, type_, cache_slot, rv),
})
}
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.
Examples found in repository?
535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553
pub fn shallow_clone(&self) -> Zval {
let mut new = Zval::new();
new.u1 = self.u1;
new.value = self.value;
// SAFETY: `u1` union is only used for easier bitmasking. It is valid to read
// from either of the variants.
//
// SAFETY: If the value if refcounted (`self.u1.type_info & Z_TYPE_FLAGS_MASK`)
// then it is valid to dereference `self.value.counted`.
unsafe {
let flags = ZvalTypeFlags::from_bits_unchecked(self.u1.type_info);
if flags.contains(ZvalTypeFlags::RefCounted) {
(*self.value.counted).gc.refcount += 1;
}
}
new
}
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
.
Examples found in repository?
535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553
pub fn shallow_clone(&self) -> Zval {
let mut new = Zval::new();
new.u1 = self.u1;
new.value = self.value;
// SAFETY: `u1` union is only used for easier bitmasking. It is valid to read
// from either of the variants.
//
// SAFETY: If the value if refcounted (`self.u1.type_info & Z_TYPE_FLAGS_MASK`)
// then it is valid to dereference `self.value.counted`.
unsafe {
let flags = ZvalTypeFlags::from_bits_unchecked(self.u1.type_info);
if flags.contains(ZvalTypeFlags::RefCounted) {
(*self.value.counted).gc.refcount += 1;
}
}
new
}
More examples
235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263
fn try_from(value: ZvalTypeFlags) -> Result<Self> {
macro_rules! contains {
($t: ident) => {
if value.contains(ZvalTypeFlags::$t) {
return Ok(DataType::$t);
}
};
}
contains!(Undef);
contains!(Null);
contains!(False);
contains!(True);
contains!(False);
contains!(Long);
contains!(Double);
contains!(String);
contains!(Array);
contains!(Resource);
contains!(Callable);
contains!(ConstantExpression);
contains!(Void);
if value.contains(ZvalTypeFlags::Object) {
return Ok(DataType::Object(None));
}
Err(Error::UnknownDatatype(0))
}
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 ZvalTypeFlags
impl Binary for ZvalTypeFlags
source§impl BitAnd<ZvalTypeFlags> for ZvalTypeFlags
impl BitAnd<ZvalTypeFlags> for ZvalTypeFlags
source§impl BitAndAssign<ZvalTypeFlags> for ZvalTypeFlags
impl BitAndAssign<ZvalTypeFlags> for ZvalTypeFlags
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<ZvalTypeFlags> for ZvalTypeFlags
impl BitOr<ZvalTypeFlags> for ZvalTypeFlags
source§fn bitor(self, other: ZvalTypeFlags) -> Self
fn bitor(self, other: ZvalTypeFlags) -> Self
Returns the union of the two sets of flags.
§type Output = ZvalTypeFlags
type Output = ZvalTypeFlags
|
operator.source§impl BitOrAssign<ZvalTypeFlags> for ZvalTypeFlags
impl BitOrAssign<ZvalTypeFlags> for ZvalTypeFlags
source§fn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Adds the set of flags.
source§impl BitXor<ZvalTypeFlags> for ZvalTypeFlags
impl BitXor<ZvalTypeFlags> for ZvalTypeFlags
source§impl BitXorAssign<ZvalTypeFlags> for ZvalTypeFlags
impl BitXorAssign<ZvalTypeFlags> for ZvalTypeFlags
source§fn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Toggles the set of flags.
source§impl Clone for ZvalTypeFlags
impl Clone for ZvalTypeFlags
source§fn clone(&self) -> ZvalTypeFlags
fn clone(&self) -> ZvalTypeFlags
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for ZvalTypeFlags
impl Debug for ZvalTypeFlags
source§impl Extend<ZvalTypeFlags> for ZvalTypeFlags
impl Extend<ZvalTypeFlags> for ZvalTypeFlags
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<ZvalTypeFlags> for ZvalTypeFlags
impl FromIterator<ZvalTypeFlags> for ZvalTypeFlags
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 ZvalTypeFlags
impl Hash for ZvalTypeFlags
source§impl LowerHex for ZvalTypeFlags
impl LowerHex for ZvalTypeFlags
source§impl Not for ZvalTypeFlags
impl Not for ZvalTypeFlags
source§impl Octal for ZvalTypeFlags
impl Octal for ZvalTypeFlags
source§impl Ord for ZvalTypeFlags
impl Ord for ZvalTypeFlags
source§fn cmp(&self, other: &ZvalTypeFlags) -> Ordering
fn cmp(&self, other: &ZvalTypeFlags) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
source§impl PartialEq<ZvalTypeFlags> for ZvalTypeFlags
impl PartialEq<ZvalTypeFlags> for ZvalTypeFlags
source§fn eq(&self, other: &ZvalTypeFlags) -> bool
fn eq(&self, other: &ZvalTypeFlags) -> bool
self
and other
values to be equal, and is used
by ==
.source§impl PartialOrd<ZvalTypeFlags> for ZvalTypeFlags
impl PartialOrd<ZvalTypeFlags> for ZvalTypeFlags
source§fn partial_cmp(&self, other: &ZvalTypeFlags) -> Option<Ordering>
fn partial_cmp(&self, other: &ZvalTypeFlags) -> 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<ZvalTypeFlags> for ZvalTypeFlags
impl Sub<ZvalTypeFlags> for ZvalTypeFlags
source§impl SubAssign<ZvalTypeFlags> for ZvalTypeFlags
impl SubAssign<ZvalTypeFlags> for ZvalTypeFlags
source§fn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Disables all flags enabled in the set.