mirror of
https://github.com/servo/servo.git
synced 2025-08-05 21:50:18 +01:00
Instead of using a simple `Atom` to identify a local font, use a data structure. This allows us to carry more information necessary to identify a local font (such as a path on MacOS). We need this for the new version of WebRender, as fonts on MacOS now require a path. This has a lot of benefits: 1. We can avoid loading fonts without paths on MacOS, which should avoid a lot of problems with flakiness and ensure we always load the same font for a given identifier. 2. This clarifies the difference between web fonts and local fonts, though there is more work to do here. 3. This avoid a *lot* of font shenanigans, such as trying to work backwards from the name of the font to the path of the font we actually matched. In general, we can remove a lot of code trying to accomplish these shenanigans. 4. Getting the font bytes always returns an `Arc` now avoiding an extra full font copy in the case of Canvas.
78 lines
2.3 KiB
Rust
78 lines
2.3 KiB
Rust
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */
|
|
|
|
// Test doesn't yet run on Mac, see https://github.com/servo/servo/pull/19928 for explanation.
|
|
#[cfg(not(target_os = "macos"))]
|
|
#[test]
|
|
fn test_font_template_descriptor() {
|
|
use std::fs::File;
|
|
use std::io::prelude::*;
|
|
use std::path::PathBuf;
|
|
|
|
use gfx::font_cache_thread::FontIdentifier;
|
|
use gfx::font_context::FontContextHandle;
|
|
use gfx::font_template::{FontTemplate, FontTemplateDescriptor};
|
|
use servo_url::ServoUrl;
|
|
use style::values::computed::font::{FontStretch, FontStyle, FontWeight};
|
|
|
|
fn descriptor(filename: &str) -> FontTemplateDescriptor {
|
|
let mut path: PathBuf = [
|
|
env!("CARGO_MANIFEST_DIR"),
|
|
"tests",
|
|
"support",
|
|
"dejavu-fonts-ttf-2.37",
|
|
"ttf",
|
|
]
|
|
.iter()
|
|
.collect();
|
|
path.push(format!("{}.ttf", filename));
|
|
|
|
let file = File::open(path.clone()).unwrap();
|
|
let mut template = FontTemplate::new(
|
|
FontIdentifier::Web(ServoUrl::from_file_path(path).unwrap()),
|
|
Some(file.bytes().map(|b| b.unwrap()).collect()),
|
|
)
|
|
.unwrap();
|
|
|
|
let context = FontContextHandle::default();
|
|
|
|
template.descriptor(&context).unwrap()
|
|
}
|
|
|
|
assert_eq!(
|
|
descriptor("DejaVuSans"),
|
|
FontTemplateDescriptor {
|
|
weight: FontWeight::NORMAL,
|
|
stretch: FontStretch::hundred(),
|
|
style: FontStyle::NORMAL,
|
|
}
|
|
);
|
|
|
|
assert_eq!(
|
|
descriptor("DejaVuSans-Bold"),
|
|
FontTemplateDescriptor {
|
|
weight: FontWeight::BOLD,
|
|
stretch: FontStretch::hundred(),
|
|
style: FontStyle::NORMAL,
|
|
}
|
|
);
|
|
|
|
assert_eq!(
|
|
descriptor("DejaVuSans-Oblique"),
|
|
FontTemplateDescriptor {
|
|
weight: FontWeight::NORMAL,
|
|
stretch: FontStretch::hundred(),
|
|
style: FontStyle::ITALIC,
|
|
}
|
|
);
|
|
|
|
assert_eq!(
|
|
descriptor("DejaVuSansCondensed-BoldOblique"),
|
|
FontTemplateDescriptor {
|
|
weight: FontWeight::BOLD,
|
|
stretch: FontStretch::from_percentage(0.875),
|
|
style: FontStyle::ITALIC,
|
|
}
|
|
);
|
|
}
|