use core::ops::{BitOr, BitOrAssign, Sub};
#[derive(Clone, Copy, Debug, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
pub struct LookupFlag(u16);
impl BitOr for LookupFlag {
type Output = Self;
fn bitor(self, rhs: Self) -> Self::Output {
Self(self.0 | rhs.0)
}
}
impl BitOrAssign for LookupFlag {
fn bitor_assign(&mut self, rhs: Self) {
self.0 |= rhs.0
}
}
impl Sub for LookupFlag {
type Output = Self;
#[inline]
fn sub(self, rhs: Self) -> Self {
Self(self.0 & !rhs.0)
}
}
impl LookupFlag {
pub const RIGHT_TO_LEFT: Self = LookupFlag(0x0001);
pub const IGNORE_BASE_GLYPHS: Self = LookupFlag(0x002);
pub const IGNORE_LIGATURES: Self = LookupFlag(0x004);
pub const IGNORE_MARKS: Self = LookupFlag(0x008);
pub const USE_MARK_FILTERING_SET: Self = LookupFlag(0x010);
const FLAG_MASK: Self = LookupFlag(0x1F);
pub fn empty() -> Self {
Self(0)
}
pub fn from_bits_truncate(bits: u16) -> Self {
const VALID_BITS: u16 = !0x00E0;
Self(bits & VALID_BITS)
}
pub fn to_bits(self) -> u16 {
self.0
}
#[inline]
pub const fn contains(&self, other: Self) -> bool {
let other = other.0 & Self::FLAG_MASK.0;
(self.0 & other) == other
}
pub fn mark_attachment_class(self) -> Option<u16> {
let val = self.0 & 0xff00;
if val == 0 {
None
} else {
Some(val >> 8)
}
}
pub fn set_mark_attachment_class(&mut self, val: u16) {
let val = (val & 0xff) << 8;
self.0 = (self.0 & 0xff) | val;
}
}
impl types::Scalar for LookupFlag {
type Raw = <u16 as types::Scalar>::Raw;
fn to_raw(self) -> Self::Raw {
self.0.to_raw()
}
fn from_raw(raw: Self::Raw) -> Self {
let t = <u16>::from_raw(raw);
Self(t)
}
}