use crate::derives::*;
use crate::values::animated::ToAnimatedZero;
use crate::Zero;
use std::fmt::{self, Write};
use style_traits::{CssWriter, ToCss};
#[derive(
Animate,
Clone,
ComputeSquaredDistance,
Copy,
Debug,
FromPrimitive,
MallocSizeOf,
Parse,
PartialEq,
SpecifiedValueInfo,
ToAnimatedValue,
ToComputedValue,
ToCss,
ToResolvedValue,
ToShmem,
ToTyped,
)]
#[repr(u8)]
#[allow(missing_docs)]
pub enum BaselineShiftKeyword {
Sub,
Super,
Top,
Center,
Bottom,
}
#[derive(
Animate,
Clone,
ComputeSquaredDistance,
Copy,
Debug,
MallocSizeOf,
PartialEq,
SpecifiedValueInfo,
ToAnimatedValue,
ToComputedValue,
ToCss,
ToResolvedValue,
ToShmem,
ToTyped,
)]
#[repr(C, u8)]
pub enum GenericBaselineShift<LengthPercentage> {
Keyword(BaselineShiftKeyword),
Length(LengthPercentage),
}
pub use self::GenericBaselineShift as BaselineShift;
impl<L: Zero> BaselineShift<L> {
#[inline]
pub fn zero() -> Self {
BaselineShift::Length(Zero::zero())
}
}
impl<L> ToAnimatedZero for BaselineShift<L> {
fn to_animated_zero(&self) -> Result<Self, ()> {
Err(())
}
}
#[derive(
Animate,
Clone,
ComputeSquaredDistance,
Debug,
MallocSizeOf,
PartialEq,
SpecifiedValueInfo,
ToComputedValue,
ToAnimatedValue,
ToAnimatedZero,
ToResolvedValue,
ToShmem,
ToTyped,
)]
#[value_info(other_values = "auto")]
#[repr(C, u8)]
pub enum GenericContainIntrinsicSize<L> {
None,
AutoNone,
Length(L),
AutoLength(L),
}
pub use self::GenericContainIntrinsicSize as ContainIntrinsicSize;
impl<L: ToCss> ToCss for ContainIntrinsicSize<L> {
fn to_css<W>(&self, dest: &mut CssWriter<W>) -> fmt::Result
where
W: Write,
{
match *self {
Self::None => dest.write_str("none"),
Self::AutoNone => dest.write_str("auto none"),
Self::Length(ref l) => l.to_css(dest),
Self::AutoLength(ref l) => {
dest.write_str("auto ")?;
l.to_css(dest)
},
}
}
}
#[derive(
Clone,
ComputeSquaredDistance,
Copy,
Debug,
MallocSizeOf,
PartialEq,
SpecifiedValueInfo,
ToComputedValue,
ToAnimatedValue,
ToAnimatedZero,
ToResolvedValue,
ToShmem,
ToTyped,
)]
#[repr(transparent)]
#[value_info(other_values = "none")]
pub struct GenericLineClamp<I>(pub I);
pub use self::GenericLineClamp as LineClamp;
impl<I: Zero> LineClamp<I> {
pub fn none() -> Self {
Self(crate::Zero::zero())
}
pub fn is_none(&self) -> bool {
self.0.is_zero()
}
}
impl<I: Zero + ToCss> ToCss for LineClamp<I> {
fn to_css<W>(&self, dest: &mut CssWriter<W>) -> fmt::Result
where
W: Write,
{
if self.is_none() {
return dest.write_str("none");
}
self.0.to_css(dest)
}
}
#[derive(
Animate,
Clone,
ComputeSquaredDistance,
Copy,
Debug,
MallocSizeOf,
Parse,
PartialEq,
SpecifiedValueInfo,
ToAnimatedValue,
ToAnimatedZero,
ToComputedValue,
ToCss,
ToResolvedValue,
ToShmem,
ToTyped,
)]
#[repr(C, u8)]
pub enum GenericPerspective<NonNegativeLength> {
Length(NonNegativeLength),
None,
}
pub use self::GenericPerspective as Perspective;
impl<L> Perspective<L> {
#[inline]
pub fn none() -> Self {
Perspective::None
}
}
#[derive(
Clone,
Copy,
Debug,
MallocSizeOf,
Parse,
PartialEq,
SpecifiedValueInfo,
ToComputedValue,
ToCss,
ToResolvedValue,
ToShmem,
ToTyped,
)]
#[repr(u8)]
#[allow(missing_docs)]
pub enum PositionProperty {
Static = 0,
Relative,
Absolute,
Fixed,
Sticky,
}
impl PositionProperty {
pub fn is_absolutely_positioned(self) -> bool {
matches!(self, Self::Absolute | Self::Fixed)
}
}
#[allow(missing_docs)]
#[derive(
Clone,
ComputeSquaredDistance,
Copy,
Debug,
Eq,
MallocSizeOf,
PartialEq,
Parse,
SpecifiedValueInfo,
ToAnimatedValue,
ToComputedValue,
ToCss,
ToResolvedValue,
ToShmem,
ToTyped,
)]
#[repr(u8)]
pub enum OverflowClipMarginBox {
ContentBox,
PaddingBox,
BorderBox,
}
#[derive(
Animate,
Clone,
ComputeSquaredDistance,
Copy,
Debug,
Eq,
MallocSizeOf,
PartialEq,
SpecifiedValueInfo,
ToAnimatedValue,
ToComputedValue,
ToAnimatedZero,
ToResolvedValue,
ToShmem,
ToTyped,
)]
#[repr(C)]
pub struct GenericOverflowClipMargin<L> {
pub offset: L,
#[animation(constant)]
pub visual_box: OverflowClipMarginBox,
}
pub use self::GenericOverflowClipMargin as OverflowClipMargin;
impl<L: Zero> GenericOverflowClipMargin<L> {
pub fn zero() -> Self {
Self {
offset: Zero::zero(),
visual_box: OverflowClipMarginBox::PaddingBox,
}
}
}
impl<L: Zero + ToCss> ToCss for OverflowClipMargin<L> {
fn to_css<W>(&self, dest: &mut CssWriter<W>) -> fmt::Result
where
W: Write,
{
if self.visual_box == OverflowClipMarginBox::PaddingBox {
return self.offset.to_css(dest);
}
self.visual_box.to_css(dest)?;
if !self.offset.is_zero() {
dest.write_char(' ')?;
self.offset.to_css(dest)?;
}
Ok(())
}
}