Skip to content

Commit

Permalink
stylo: Bug 1355345 - Support font-display descriptor in @font-face rule
Browse files Browse the repository at this point in the history
  • Loading branch information
ferjm authored and nox committed May 18, 2017
1 parent a088621 commit 96a23d9
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 2 deletions.
16 changes: 15 additions & 1 deletion components/style/font_face.rs
Expand Up @@ -72,6 +72,17 @@ impl ToCss for UrlSource {
}
}

/// A font-display value for a @font-face rule.
/// The font-display descriptor determines how a font face is displayed based
/// on whether and when it is downloaded and ready to use.
define_css_keyword_enum!(FontDisplay:
"auto" => Auto,
"block" => Block,
"swap" => Swap,
"fallback" => Fallback,
"optional" => Optional);
add_impls_for_keyword_enum!(FontDisplay);

/// Parse the block inside a `@font-face` rule.
///
/// Note that the prelude parsing code lives in the `stylesheets` module.
Expand Down Expand Up @@ -332,6 +343,9 @@ font_face_descriptors! {
/// The stretch of this font face
"font-stretch" stretch / mStretch: font_stretch::T = font_stretch::T::normal,

/// The display of this font face
"font-display" display / mDisplay: FontDisplay = FontDisplay::Auto,

/// The ranges of code points outside of which this font face should not be used.
"unicode-range" unicode_range / mUnicodeRange: Vec<UnicodeRange> = vec![
UnicodeRange { start: 0, end: 0x10FFFF }
Expand All @@ -342,7 +356,7 @@ font_face_descriptors! {
font_feature_settings::T::Normal
},

// FIXME: add font-language-override, and font-display.
// FIXME: add font-language-override.
]
}

Expand Down
14 changes: 13 additions & 1 deletion components/style/gecko/rules.rs
Expand Up @@ -9,7 +9,7 @@ use computed_values::{font_feature_settings, font_stretch, font_style, font_weig
use computed_values::font_family::FamilyName;
use counter_style;
use cssparser::UnicodeRange;
use font_face::{FontFaceRuleData, Source};
use font_face::{FontFaceRuleData, Source, FontDisplay};
use gecko_bindings::bindings;
use gecko_bindings::structs::{self, nsCSSFontFaceRule, nsCSSValue};
use gecko_bindings::structs::{nsCSSCounterDesc, nsCSSCounterStyleRule};
Expand Down Expand Up @@ -137,6 +137,18 @@ impl ToNsCssValue for Vec<UnicodeRange> {
}
}

impl ToNsCssValue for FontDisplay {
fn convert(self, nscssvalue: &mut nsCSSValue) {
nscssvalue.set_enum(match self {
FontDisplay::Auto => structs::NS_FONT_DISPLAY_AUTO,
FontDisplay::Block => structs::NS_FONT_DISPLAY_BLOCK,
FontDisplay::Swap => structs::NS_FONT_DISPLAY_SWAP,
FontDisplay::Fallback => structs::NS_FONT_DISPLAY_FALLBACK,
FontDisplay::Optional => structs::NS_FONT_DISPLAY_OPTIONAL,
} as i32)
}
}

impl From<FontFaceRuleData> for FontFaceRule {
fn from(data: FontFaceRuleData) -> FontFaceRule {
let mut result = unsafe {
Expand Down

0 comments on commit 96a23d9

Please sign in to comment.