mirror of
https://github.com/servo/servo.git
synced 2025-08-17 11:25:35 +01:00
stylo: Support font-variation-settings
This commit is contained in:
parent
dd1cc6bb45
commit
9ed5a7a05e
6 changed files with 259 additions and 117 deletions
|
@ -2196,7 +2196,8 @@ pub mod root {
|
|||
#[repr(C)]
|
||||
#[derive(Debug, Copy)]
|
||||
pub struct FontVariation {
|
||||
pub _bindgen_opaque_blob: [u32; 2usize],
|
||||
pub mTag: u32,
|
||||
pub mValue: f32,
|
||||
}
|
||||
#[test]
|
||||
fn bindgen_test_layout_FontVariation() {
|
||||
|
@ -2207,6 +2208,17 @@ pub mod root {
|
|||
concat ! (
|
||||
"Alignment of " , stringify ! ( FontVariation )
|
||||
));
|
||||
assert_eq! (unsafe {
|
||||
& ( * ( 0 as * const FontVariation ) ) . mTag as *
|
||||
const _ as usize } , 0usize , concat ! (
|
||||
"Alignment of field: " , stringify ! (
|
||||
FontVariation ) , "::" , stringify ! ( mTag ) ));
|
||||
assert_eq! (unsafe {
|
||||
& ( * ( 0 as * const FontVariation ) ) . mValue as
|
||||
* const _ as usize } , 4usize , concat ! (
|
||||
"Alignment of field: " , stringify ! (
|
||||
FontVariation ) , "::" , stringify ! ( mValue )
|
||||
));
|
||||
}
|
||||
impl Clone for FontVariation {
|
||||
fn clone(&self) -> Self { *self }
|
||||
|
|
|
@ -2102,7 +2102,8 @@ pub mod root {
|
|||
#[repr(C)]
|
||||
#[derive(Debug, Copy)]
|
||||
pub struct FontVariation {
|
||||
pub _bindgen_opaque_blob: [u32; 2usize],
|
||||
pub mTag: u32,
|
||||
pub mValue: f32,
|
||||
}
|
||||
#[test]
|
||||
fn bindgen_test_layout_FontVariation() {
|
||||
|
@ -2113,6 +2114,17 @@ pub mod root {
|
|||
concat ! (
|
||||
"Alignment of " , stringify ! ( FontVariation )
|
||||
));
|
||||
assert_eq! (unsafe {
|
||||
& ( * ( 0 as * const FontVariation ) ) . mTag as *
|
||||
const _ as usize } , 0usize , concat ! (
|
||||
"Alignment of field: " , stringify ! (
|
||||
FontVariation ) , "::" , stringify ! ( mTag ) ));
|
||||
assert_eq! (unsafe {
|
||||
& ( * ( 0 as * const FontVariation ) ) . mValue as
|
||||
* const _ as usize } , 4usize , concat ! (
|
||||
"Alignment of field: " , stringify ! (
|
||||
FontVariation ) , "::" , stringify ! ( mValue )
|
||||
));
|
||||
}
|
||||
impl Clone for FontVariation {
|
||||
fn clone(&self) -> Self { *self }
|
||||
|
|
|
@ -17,6 +17,7 @@ use gecko_bindings::sugar::ns_css_value::ToNsCssValue;
|
|||
use gecko_bindings::sugar::refptr::{RefPtr, UniqueRefPtr};
|
||||
use shared_lock::{ToCssWithGuard, SharedRwLockReadGuard};
|
||||
use std::{fmt, str};
|
||||
use values::generics::FontSettings;
|
||||
|
||||
/// A @font-face rule
|
||||
pub type FontFaceRule = RefPtr<nsCSSFontFaceRule>;
|
||||
|
@ -36,8 +37,8 @@ impl ToNsCssValue for font_weight::T {
|
|||
impl ToNsCssValue for font_feature_settings::T {
|
||||
fn convert(self, nscssvalue: &mut nsCSSValue) {
|
||||
match self {
|
||||
font_feature_settings::T::Normal => nscssvalue.set_normal(),
|
||||
font_feature_settings::T::Tag(tags) => {
|
||||
FontSettings::Normal => nscssvalue.set_normal(),
|
||||
FontSettings::Tag(tags) => {
|
||||
nscssvalue.set_pair_list(tags.into_iter().map(|entry| {
|
||||
let mut feature = nsCSSValue::null();
|
||||
let mut raw = [0u8; 4];
|
||||
|
@ -45,7 +46,7 @@ impl ToNsCssValue for font_feature_settings::T {
|
|||
feature.set_string(str::from_utf8(&raw).unwrap());
|
||||
|
||||
let mut index = nsCSSValue::null();
|
||||
index.set_integer(entry.value as i32);
|
||||
index.set_integer(entry.value.0 as i32);
|
||||
|
||||
(feature, index)
|
||||
}))
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue