mirror of
https://github.com/servo/servo.git
synced 2025-08-03 04:30:10 +01:00
style: Try to bring some more sanity into our font code.
It's not very easy to understand on its current state, and it causes subtle bugs like bug 1533654. It could be simpler if we centralized where the interactions between properties are handled. This patch does this. This patch also changes how MathML script sizes are tracked when scriptlevel changes and they have relative fonts in between. With this patch, any explicitly specified font-size is treated the same (being a scriptlevel boundary), regardless of whether it's either an absolute size, a relative size, or a wide keyword. Relative lengths always resolve relative to the constrained size, which allows us to avoid the double font-size computation, and not give up on sanity with keyword font-sizes. I think given no other browser supports scriptlevel it seems like the right trade-off. Differential Revision: https://phabricator.services.mozilla.com/D23070
This commit is contained in:
parent
77a75596bb
commit
aa5ea337da
8 changed files with 290 additions and 498 deletions
|
@ -548,13 +548,16 @@ impl ToComputedValue for FontFamily {
|
|||
|
||||
fn to_computed_value(&self, context: &Context) -> Self::ComputedValue {
|
||||
match *self {
|
||||
FontFamily::Values(ref v) => computed::FontFamily(v.clone()),
|
||||
FontFamily::Values(ref v) => computed::FontFamily {
|
||||
families: v.clone(),
|
||||
is_system_font: false,
|
||||
},
|
||||
FontFamily::System(_) => self.compute_system(context),
|
||||
}
|
||||
}
|
||||
|
||||
fn from_computed_value(other: &computed::FontFamily) -> Self {
|
||||
FontFamily::Values(other.0.clone())
|
||||
FontFamily::Values(other.families.clone())
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -958,48 +961,6 @@ impl FontSize {
|
|||
"larger" => Ok(FontSize::Larger),
|
||||
}
|
||||
}
|
||||
|
||||
#[allow(unused_mut)]
|
||||
/// Cascade `font-size` with specified value
|
||||
pub fn cascade_specified_font_size(
|
||||
context: &mut Context,
|
||||
specified_value: &FontSize,
|
||||
mut computed: computed::FontSize,
|
||||
) {
|
||||
// we could use clone_language and clone_font_family() here but that's
|
||||
// expensive. Do it only in gecko mode for now.
|
||||
#[cfg(feature = "gecko")]
|
||||
{
|
||||
// if the language or generic changed, we need to recalculate
|
||||
// the font size from the stored font-size origin information.
|
||||
if context.builder.get_font().gecko().mLanguage.mRawPtr !=
|
||||
context.builder.get_parent_font().gecko().mLanguage.mRawPtr ||
|
||||
context.builder.get_font().gecko().mGenericID !=
|
||||
context.builder.get_parent_font().gecko().mGenericID
|
||||
{
|
||||
if let Some(info) = computed.keyword_info {
|
||||
computed.size = info.to_computed_value(context);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
let device = context.builder.device;
|
||||
let mut font = context.builder.take_font();
|
||||
let parent_unconstrained = {
|
||||
let parent_font = context.builder.get_parent_font();
|
||||
font.apply_font_size(computed, parent_font, device)
|
||||
};
|
||||
context.builder.put_font(font);
|
||||
|
||||
if let Some(parent) = parent_unconstrained {
|
||||
let new_unconstrained = specified_value
|
||||
.to_computed_value_against(context, FontBaseSize::Custom(Au::from(parent)));
|
||||
context
|
||||
.builder
|
||||
.mutate_font()
|
||||
.apply_unconstrained_font_size(new_unconstrained.size);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl Parse for FontSize {
|
||||
|
|
|
@ -82,17 +82,12 @@ pub enum FontBaseSize {
|
|||
///
|
||||
/// FIXME(emilio): This is very complex, and should go away.
|
||||
InheritedStyleButStripEmUnits,
|
||||
/// Use a custom base size.
|
||||
///
|
||||
/// FIXME(emilio): This is very dubious, and only used for MathML.
|
||||
Custom(Au),
|
||||
}
|
||||
|
||||
impl FontBaseSize {
|
||||
/// Calculate the actual size for a given context
|
||||
pub fn resolve(&self, context: &Context) -> Au {
|
||||
match *self {
|
||||
FontBaseSize::Custom(size) => size,
|
||||
FontBaseSize::CurrentStyle => context.style().get_font().clone_font_size().size(),
|
||||
FontBaseSize::InheritedStyleButStripEmUnits | FontBaseSize::InheritedStyle => {
|
||||
context.style().get_parent_font().clone_font_size().size()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue