mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-22 09:21:57 -05:00
LibWeb: Make FontPlugin::generic_font_name() return FlyString
This commit is contained in:
parent
13db3c5ce0
commit
4da1f4e836
6 changed files with 23 additions and 23 deletions
|
@ -34,11 +34,11 @@ FontPlugin::FontPlugin(bool is_layout_test_mode)
|
||||||
update_generic_fonts();
|
update_generic_fonts();
|
||||||
|
|
||||||
auto default_font_name = generic_font_name(Web::Platform::GenericFont::UiSansSerif);
|
auto default_font_name = generic_font_name(Web::Platform::GenericFont::UiSansSerif);
|
||||||
m_default_font = Gfx::FontDatabase::the().get(MUST(String::from_deprecated_string(default_font_name)), 12.0, 400, Gfx::FontWidth::Normal, 0);
|
m_default_font = Gfx::FontDatabase::the().get(default_font_name, 12.0, 400, Gfx::FontWidth::Normal, 0);
|
||||||
VERIFY(m_default_font);
|
VERIFY(m_default_font);
|
||||||
|
|
||||||
auto default_fixed_width_font_name = generic_font_name(Web::Platform::GenericFont::UiMonospace);
|
auto default_fixed_width_font_name = generic_font_name(Web::Platform::GenericFont::UiMonospace);
|
||||||
m_default_fixed_width_font = Gfx::FontDatabase::the().get(MUST(String::from_deprecated_string(default_fixed_width_font_name)), 12.0, 400, Gfx::FontWidth::Normal, 0);
|
m_default_fixed_width_font = Gfx::FontDatabase::the().get(default_fixed_width_font_name, 12.0, 400, Gfx::FontWidth::Normal, 0);
|
||||||
VERIFY(m_default_fixed_width_font);
|
VERIFY(m_default_fixed_width_font);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -66,16 +66,16 @@ void FontPlugin::update_generic_fonts()
|
||||||
|
|
||||||
m_generic_font_names.resize(static_cast<size_t>(Web::Platform::GenericFont::__Count));
|
m_generic_font_names.resize(static_cast<size_t>(Web::Platform::GenericFont::__Count));
|
||||||
|
|
||||||
auto update_mapping = [&](Web::Platform::GenericFont generic_font, ReadonlySpan<DeprecatedString> fallbacks) {
|
auto update_mapping = [&](Web::Platform::GenericFont generic_font, ReadonlySpan<FlyString> fallbacks) {
|
||||||
if (m_is_layout_test_mode) {
|
if (m_is_layout_test_mode) {
|
||||||
m_generic_font_names[static_cast<size_t>(generic_font)] = "SerenitySans";
|
m_generic_font_names[static_cast<size_t>(generic_font)] = "SerenitySans"_fly_string;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
RefPtr<Gfx::Font const> gfx_font;
|
RefPtr<Gfx::Font const> gfx_font;
|
||||||
|
|
||||||
for (auto& fallback : fallbacks) {
|
for (auto& fallback : fallbacks) {
|
||||||
gfx_font = Gfx::FontDatabase::the().get(MUST(String::from_deprecated_string(fallback)), 16, 400, Gfx::FontWidth::Normal, 0, Gfx::Font::AllowInexactSizeMatch::Yes);
|
gfx_font = Gfx::FontDatabase::the().get(fallback, 16, 400, Gfx::FontWidth::Normal, 0, Gfx::Font::AllowInexactSizeMatch::Yes);
|
||||||
if (gfx_font)
|
if (gfx_font)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -87,16 +87,16 @@ void FontPlugin::update_generic_fonts()
|
||||||
gfx_font = Gfx::FontDatabase::default_font();
|
gfx_font = Gfx::FontDatabase::default_font();
|
||||||
}
|
}
|
||||||
|
|
||||||
m_generic_font_names[static_cast<size_t>(generic_font)] = gfx_font->family().to_deprecated_string();
|
m_generic_font_names[static_cast<size_t>(generic_font)] = gfx_font->family();
|
||||||
};
|
};
|
||||||
|
|
||||||
// Fallback fonts to look for if Gfx::Font can't load expected font
|
// Fallback fonts to look for if Gfx::Font can't load expected font
|
||||||
// The lists are basically arbitrary, taken from https://www.w3.org/Style/Examples/007/fonts.en.html
|
// The lists are basically arbitrary, taken from https://www.w3.org/Style/Examples/007/fonts.en.html
|
||||||
Vector<DeprecatedString> cursive_fallbacks { "Comic Sans MS", "Comic Sans", "Apple Chancery", "Bradley Hand", "Brush Script MT", "Snell Roundhand", "URW Chancery L" };
|
Vector<FlyString> cursive_fallbacks { "Comic Sans MS"_fly_string, "Comic Sans"_fly_string, "Apple Chancery"_fly_string, "Bradley Hand"_fly_string, "Brush Script MT"_fly_string, "Snell Roundhand"_fly_string, "URW Chancery L"_fly_string };
|
||||||
Vector<DeprecatedString> fantasy_fallbacks { "Impact", "Luminari", "Chalkduster", "Jazz LET", "Blippo", "Stencil Std", "Marker Felt", "Trattatello" };
|
Vector<FlyString> fantasy_fallbacks { "Impact"_fly_string, "Luminari"_fly_string, "Chalkduster"_fly_string, "Jazz LET"_fly_string, "Blippo"_fly_string, "Stencil Std"_fly_string, "Marker Felt"_fly_string, "Trattatello"_fly_string };
|
||||||
Vector<DeprecatedString> monospace_fallbacks { "Andale Mono", "Courier New", "Courier", "FreeMono", "OCR A Std", "DejaVu Sans Mono", "Liberation Mono", "Csilla" };
|
Vector<FlyString> monospace_fallbacks { "Andale Mono"_fly_string, "Courier New"_fly_string, "Courier"_fly_string, "FreeMono"_fly_string, "OCR A Std"_fly_string, "DejaVu Sans Mono"_fly_string, "Liberation Mono"_fly_string, "Csilla"_fly_string };
|
||||||
Vector<DeprecatedString> sans_serif_fallbacks { "Arial", "Helvetica", "Verdana", "Trebuchet MS", "Gill Sans", "Noto Sans", "Avantgarde", "Optima", "Arial Narrow", "Liberation Sans", "Katica" };
|
Vector<FlyString> sans_serif_fallbacks { "Arial"_fly_string, "Helvetica"_fly_string, "Verdana"_fly_string, "Trebuchet MS"_fly_string, "Gill Sans"_fly_string, "Noto Sans"_fly_string, "Avantgarde"_fly_string, "Optima"_fly_string, "Arial Narrow"_fly_string, "Liberation Sans"_fly_string, "Katica"_fly_string };
|
||||||
Vector<DeprecatedString> serif_fallbacks { "Times", "Times New Roman", "Didot", "Georgia", "Palatino", "Bookman", "New Century Schoolbook", "American Typewriter", "Liberation Serif", "Roman" };
|
Vector<FlyString> serif_fallbacks { "Times"_fly_string, "Times New Roman"_fly_string, "Didot"_fly_string, "Georgia"_fly_string, "Palatino"_fly_string, "Bookman"_fly_string, "New Century Schoolbook"_fly_string, "American Typewriter"_fly_string, "Liberation Serif"_fly_string, "Roman"_fly_string };
|
||||||
|
|
||||||
update_mapping(Web::Platform::GenericFont::Cursive, cursive_fallbacks);
|
update_mapping(Web::Platform::GenericFont::Cursive, cursive_fallbacks);
|
||||||
update_mapping(Web::Platform::GenericFont::Fantasy, fantasy_fallbacks);
|
update_mapping(Web::Platform::GenericFont::Fantasy, fantasy_fallbacks);
|
||||||
|
@ -109,7 +109,7 @@ void FontPlugin::update_generic_fonts()
|
||||||
update_mapping(Web::Platform::GenericFont::UiSerif, serif_fallbacks);
|
update_mapping(Web::Platform::GenericFont::UiSerif, serif_fallbacks);
|
||||||
}
|
}
|
||||||
|
|
||||||
DeprecatedString FontPlugin::generic_font_name(Web::Platform::GenericFont generic_font)
|
FlyString FontPlugin::generic_font_name(Web::Platform::GenericFont generic_font)
|
||||||
{
|
{
|
||||||
return m_generic_font_names[static_cast<size_t>(generic_font)];
|
return m_generic_font_names[static_cast<size_t>(generic_font)];
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,12 +19,12 @@ public:
|
||||||
|
|
||||||
virtual Gfx::Font& default_font() override;
|
virtual Gfx::Font& default_font() override;
|
||||||
virtual Gfx::Font& default_fixed_width_font() override;
|
virtual Gfx::Font& default_fixed_width_font() override;
|
||||||
virtual DeprecatedString generic_font_name(Web::Platform::GenericFont) override;
|
virtual FlyString generic_font_name(Web::Platform::GenericFont) override;
|
||||||
|
|
||||||
void update_generic_fonts();
|
void update_generic_fonts();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Vector<DeprecatedString> m_generic_font_names;
|
Vector<FlyString> m_generic_font_names;
|
||||||
RefPtr<Gfx::Font> m_default_font;
|
RefPtr<Gfx::Font> m_default_font;
|
||||||
RefPtr<Gfx::Font> m_default_fixed_width_font;
|
RefPtr<Gfx::Font> m_default_fixed_width_font;
|
||||||
bool m_is_layout_test_mode { false };
|
bool m_is_layout_test_mode { false };
|
||||||
|
|
|
@ -2001,7 +2001,7 @@ RefPtr<Gfx::Font const> StyleComputer::compute_font_for_style_values(DOM::Elemen
|
||||||
|
|
||||||
float const font_size_in_pt = font_size_in_px * 0.75f;
|
float const font_size_in_pt = font_size_in_px * 0.75f;
|
||||||
|
|
||||||
auto find_font = [&](String const& family) -> RefPtr<Gfx::Font const> {
|
auto find_font = [&](FlyString const& family) -> RefPtr<Gfx::Font const> {
|
||||||
font_selector = { family, font_size_in_pt, weight, width, slope };
|
font_selector = { family, font_size_in_pt, weight, width, slope };
|
||||||
|
|
||||||
FontFaceKey key {
|
FontFaceKey key {
|
||||||
|
@ -2060,7 +2060,7 @@ RefPtr<Gfx::Font const> StyleComputer::compute_font_for_style_values(DOM::Elemen
|
||||||
default:
|
default:
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
return find_font(String::from_deprecated_string(Platform::FontPlugin::the().generic_font_name(generic_font)).release_value_but_fixme_should_propagate_errors());
|
return find_font(Platform::FontPlugin::the().generic_font_name(generic_font));
|
||||||
};
|
};
|
||||||
|
|
||||||
RefPtr<Gfx::Font const> found_font;
|
RefPtr<Gfx::Font const> found_font;
|
||||||
|
|
|
@ -34,7 +34,7 @@ public:
|
||||||
virtual Gfx::Font& default_font() = 0;
|
virtual Gfx::Font& default_font() = 0;
|
||||||
virtual Gfx::Font& default_fixed_width_font() = 0;
|
virtual Gfx::Font& default_fixed_width_font() = 0;
|
||||||
|
|
||||||
virtual DeprecatedString generic_font_name(GenericFont) = 0;
|
virtual FlyString generic_font_name(GenericFont) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,7 +29,7 @@ Gfx::Font& FontPluginSerenity::default_fixed_width_font()
|
||||||
return Gfx::FontDatabase::default_fixed_width_font();
|
return Gfx::FontDatabase::default_fixed_width_font();
|
||||||
}
|
}
|
||||||
|
|
||||||
DeprecatedString FontPluginSerenity::generic_font_name(GenericFont generic_font)
|
FlyString FontPluginSerenity::generic_font_name(GenericFont generic_font)
|
||||||
{
|
{
|
||||||
// FIXME: Make these configurable at the browser settings level. Fall back to system defaults.
|
// FIXME: Make these configurable at the browser settings level. Fall back to system defaults.
|
||||||
switch (generic_font) {
|
switch (generic_font) {
|
||||||
|
@ -37,15 +37,15 @@ DeprecatedString FontPluginSerenity::generic_font_name(GenericFont generic_font)
|
||||||
case GenericFont::UiSansSerif:
|
case GenericFont::UiSansSerif:
|
||||||
case GenericFont::Cursive:
|
case GenericFont::Cursive:
|
||||||
case GenericFont::UiRounded:
|
case GenericFont::UiRounded:
|
||||||
return default_font().family().to_deprecated_string();
|
return default_font().family();
|
||||||
case GenericFont::Monospace:
|
case GenericFont::Monospace:
|
||||||
case GenericFont::UiMonospace:
|
case GenericFont::UiMonospace:
|
||||||
return default_fixed_width_font().family().to_deprecated_string();
|
return default_fixed_width_font().family();
|
||||||
case GenericFont::Serif:
|
case GenericFont::Serif:
|
||||||
case GenericFont::UiSerif:
|
case GenericFont::UiSerif:
|
||||||
return "Roman";
|
return "Roman"_fly_string;
|
||||||
case GenericFont::Fantasy:
|
case GenericFont::Fantasy:
|
||||||
return "Comic Book";
|
return "Comic Book"_fly_string;
|
||||||
case GenericFont::__Count:
|
case GenericFont::__Count:
|
||||||
VERIFY_NOT_REACHED();
|
VERIFY_NOT_REACHED();
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,7 @@ public:
|
||||||
|
|
||||||
virtual Gfx::Font& default_font() override;
|
virtual Gfx::Font& default_font() override;
|
||||||
virtual Gfx::Font& default_fixed_width_font() override;
|
virtual Gfx::Font& default_fixed_width_font() override;
|
||||||
virtual DeprecatedString generic_font_name(GenericFont) override;
|
virtual FlyString generic_font_name(GenericFont) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue