| Index: components/font_service/font_service_app.cc
|
| diff --git a/components/font_service/font_service_app.cc b/components/font_service/font_service_app.cc
|
| deleted file mode 100644
|
| index 77f03a434b0712d8d5ecf13e8e95d95bc0c45c3a..0000000000000000000000000000000000000000
|
| --- a/components/font_service/font_service_app.cc
|
| +++ /dev/null
|
| @@ -1,123 +0,0 @@
|
| -// Copyright 2015 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 "components/font_service/font_service_app.h"
|
| -
|
| -#include "base/files/file.h"
|
| -#include "base/files/file_path.h"
|
| -#include "mojo/application/public/cpp/application_connection.h"
|
| -#include "mojo/platform_handle/platform_handle_functions.h"
|
| -
|
| -COMPILE_ASSERT(static_cast<uint32>(SkTypeface::kNormal) ==
|
| - static_cast<uint32>(font_service::TYPEFACE_STYLE_NORMAL),
|
| - typeface_flags_should_match);
|
| -COMPILE_ASSERT(static_cast<uint32>(SkTypeface::kBold) ==
|
| - static_cast<uint32>(font_service::TYPEFACE_STYLE_BOLD),
|
| - typeface_flags_should_match);
|
| -COMPILE_ASSERT(static_cast<uint32>(SkTypeface::kItalic) ==
|
| - static_cast<uint32>(font_service::TYPEFACE_STYLE_ITALIC),
|
| - typeface_flags_should_match);
|
| -COMPILE_ASSERT(
|
| - static_cast<uint32>(SkTypeface::kBoldItalic) ==
|
| - static_cast<uint32>(font_service::TYPEFACE_STYLE_BOLD_ITALIC),
|
| - typeface_flags_should_match);
|
| -
|
| -namespace {
|
| -
|
| -mojo::ScopedHandle GetHandleForPath(const base::FilePath& path) {
|
| - if (path.empty())
|
| - return mojo::ScopedHandle();
|
| -
|
| - mojo::ScopedHandle to_pass;
|
| - base::File file(path, base::File::FLAG_OPEN | base::File::FLAG_READ);
|
| - if (!file.IsValid()) {
|
| - LOG(WARNING) << "file not valid, path=" << path.value();
|
| - return mojo::ScopedHandle();
|
| - }
|
| -
|
| - MojoHandle mojo_handle;
|
| - MojoResult create_result =
|
| - MojoCreatePlatformHandleWrapper(file.TakePlatformFile(), &mojo_handle);
|
| - if (create_result != MOJO_RESULT_OK) {
|
| - LOG(WARNING) << "unable to create wrapper, path=" << path.value()
|
| - << "result=" << create_result;
|
| - return mojo::ScopedHandle();
|
| - }
|
| -
|
| - return mojo::ScopedHandle(mojo::Handle(mojo_handle)).Pass();
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -namespace font_service {
|
| -
|
| -FontServiceApp::FontServiceApp() {}
|
| -
|
| -FontServiceApp::~FontServiceApp() {}
|
| -
|
| -void FontServiceApp::Initialize(mojo::ApplicationImpl* app) {}
|
| -
|
| -bool FontServiceApp::ConfigureIncomingConnection(
|
| - mojo::ApplicationConnection* connection) {
|
| - connection->AddService(this);
|
| - return true;
|
| -}
|
| -
|
| -void FontServiceApp::Create(mojo::ApplicationConnection* connection,
|
| - mojo::InterfaceRequest<FontService> request) {
|
| - bindings_.AddBinding(this, request.Pass());
|
| -}
|
| -
|
| -void FontServiceApp::MatchFamilyName(const mojo::String& family_name,
|
| - TypefaceStyle requested_style,
|
| - const MatchFamilyNameCallback& callback) {
|
| - SkFontConfigInterface::FontIdentity result_identity;
|
| - SkString result_family;
|
| - SkTypeface::Style result_style;
|
| - SkFontConfigInterface* fc =
|
| - SkFontConfigInterface::GetSingletonDirectInterface();
|
| - const bool r = fc->matchFamilyName(
|
| - family_name.data(), static_cast<SkTypeface::Style>(requested_style),
|
| - &result_identity, &result_family, &result_style);
|
| -
|
| - if (!r) {
|
| - callback.Run(nullptr, "", TYPEFACE_STYLE_NORMAL);
|
| - return;
|
| - }
|
| -
|
| - // Stash away the returned path, so we can give it an ID (index)
|
| - // which will later be given to us in a request to open the file.
|
| - int index = FindOrAddPath(result_identity.fString);
|
| -
|
| - FontIdentityPtr identity(FontIdentity::New());
|
| - identity->id = static_cast<uint32_t>(index);
|
| - identity->ttc_index = result_identity.fTTCIndex;
|
| - identity->str_representation = result_identity.fString.c_str();
|
| -
|
| - callback.Run(identity.Pass(), result_family.c_str(),
|
| - static_cast<TypefaceStyle>(result_style));
|
| -}
|
| -
|
| -void FontServiceApp::OpenStream(uint32_t id_number,
|
| - const OpenStreamCallback& callback) {
|
| - mojo::ScopedHandle handle;
|
| - if (id_number < static_cast<uint32_t>(paths_.count())) {
|
| - handle =
|
| - GetHandleForPath(base::FilePath(paths_[id_number]->c_str())).Pass();
|
| - }
|
| -
|
| - callback.Run(handle.Pass());
|
| -}
|
| -
|
| -int FontServiceApp::FindOrAddPath(const SkString& path) {
|
| - int count = paths_.count();
|
| - for (int i = 0; i < count; ++i) {
|
| - if (path == *paths_[i])
|
| - return i;
|
| - }
|
| - *paths_.append() = new SkString(path);
|
| - return count;
|
| -}
|
| -
|
| -} // namespace font_service
|
|
|