blob: f207d6f84ff8792a871d784cb09f8d6fff9e4687 [file] [log] [blame]
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "content/child/child_process_sandbox_support_impl_linux.h"
#include <stddef.h>
#include <limits>
#include <memory>
#include "base/logging.h"
#include "base/trace_event/trace_event.h"
#include "components/services/font/public/cpp/font_loader.h"
#include "components/services/font/public/interfaces/font_service.mojom.h"
#include "third_party/blink/public/platform/linux/out_of_process_font.h"
#include "third_party/blink/public/platform/web_font_render_style.h"
#include "third_party/blink/public/platform/web_string.h"
#include "third_party/blink/public/platform/web_vector.h"
namespace content {
WebSandboxSupportLinux::WebSandboxSupportLinux(
sk_sp<font_service::FontLoader> font_loader)
: font_loader_(font_loader) {}
WebSandboxSupportLinux::~WebSandboxSupportLinux() = default;
void WebSandboxSupportLinux::GetFallbackFontForCharacter(
blink::WebUChar32 character,
const char* preferred_locale,
blink::OutOfProcessFont* fallback_font) {
TRACE_EVENT0("fonts", "WebSandboxSupportLinux::GetFallbackFontForCharacter");
{
base::AutoLock lock(lock_);
const auto iter = unicode_font_families_.find(character);
if (iter != unicode_font_families_.end()) {
*fallback_font = iter->second;
return;
}
}
font_service::mojom::FontIdentityPtr font_identity;
bool is_bold = false;
bool is_italic = false;
std::string family_name;
if (!font_loader_->FallbackFontForCharacter(character, preferred_locale,
&font_identity, &family_name,
&is_bold, &is_italic)) {
LOG(ERROR) << "FontService fallback request does not receive a response.";
return;
}
// TODO(drott): Perhaps take OutOfProcessFont out of the picture here and pass
// mojo FontIdentityPtr directly?
fallback_font->name =
blink::WebString::FromUTF8(family_name.c_str(), family_name.length());
fallback_font->fontconfig_interface_id = font_identity->id;
fallback_font->filename.Assign(font_identity->str_representation.c_str(),
font_identity->str_representation.length());
fallback_font->ttc_index = font_identity->ttc_index;
fallback_font->is_bold = is_bold;
fallback_font->is_italic = is_italic;
base::AutoLock lock(lock_);
unicode_font_families_.emplace(character, *fallback_font);
}
void WebSandboxSupportLinux::MatchFontByPostscriptNameOrFullFontName(
const char* font_unique_name,
blink::OutOfProcessFont* fallback_font) {
TRACE_EVENT0(
"fonts",
"WebSandboxSupportLinux::MatchFontByPostscriptNameOrFullFontName");
font_service::mojom::FontIdentityPtr font_identity;
std::string family_name;
if (!font_loader_->MatchFontByPostscriptNameOrFullFontName(font_unique_name,
&font_identity)) {
LOG(ERROR) << "FontService unique font name matching request did not "
"receive a response.";
return;
}
fallback_font->fontconfig_interface_id = font_identity->id;
fallback_font->filename.Assign(font_identity->str_representation.c_str(),
font_identity->str_representation.length());
fallback_font->ttc_index = font_identity->ttc_index;
}
void WebSandboxSupportLinux::GetWebFontRenderStyleForStrike(
const char* family,
int size,
bool is_bold,
bool is_italic,
float device_scale_factor,
blink::WebFontRenderStyle* out) {
TRACE_EVENT0("fonts",
"WebSandboxSupportLinux::GetWebFontRenderStyleForStrike");
font_service::mojom::FontIdentityPtr font_identity;
*out = blink::WebFontRenderStyle();
if (size < 0 || size > std::numeric_limits<uint16_t>::max())
return;
font_service::mojom::FontRenderStylePtr font_render_style;
if (!font_loader_->FontRenderStyleForStrike(family, size, is_bold, is_italic,
device_scale_factor,
&font_render_style) ||
font_render_style.is_null()) {
LOG(ERROR) << "GetRenderStyleForStrike did not receive a response for "
"family and size: "
<< (family ? family : "<empty>") << ", " << size;
return;
}
out->use_bitmaps = static_cast<char>(font_render_style->use_bitmaps);
out->use_auto_hint = static_cast<char>(font_render_style->use_autohint);
out->use_hinting = static_cast<char>(font_render_style->use_hinting);
out->hint_style = font_render_style->hint_style;
out->use_anti_alias = static_cast<char>(font_render_style->use_antialias);
out->use_subpixel_rendering =
static_cast<char>(font_render_style->use_subpixel_rendering);
out->use_subpixel_positioning =
static_cast<char>(font_render_style->use_subpixel_positioning);
}
} // namespace content