From 26a029d407be480d791972afb5975cf62c9360a6 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Fri, 19 Apr 2024 02:47:55 +0200 Subject: Adding upstream version 124.0.1. Signed-off-by: Daniel Baumann --- gfx/2d/NativeFontResourceFreeType.cpp | 92 +++++++++++++++++++++++++++++++++++ 1 file changed, 92 insertions(+) create mode 100644 gfx/2d/NativeFontResourceFreeType.cpp (limited to 'gfx/2d/NativeFontResourceFreeType.cpp') diff --git a/gfx/2d/NativeFontResourceFreeType.cpp b/gfx/2d/NativeFontResourceFreeType.cpp new file mode 100644 index 0000000000..e00dfafe21 --- /dev/null +++ b/gfx/2d/NativeFontResourceFreeType.cpp @@ -0,0 +1,92 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set ts=8 sts=2 et sw=2 tw=80: */ +/* 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 http://mozilla.org/MPL/2.0/. */ + +#include "NativeFontResourceFreeType.h" +#include "UnscaledFontFreeType.h" + +namespace mozilla::gfx { + +NativeFontResourceFreeType::NativeFontResourceFreeType( + UniquePtr&& aFontData, uint32_t aDataLength, + FT_Library aFTLibrary) + : NativeFontResource(aDataLength), + mFontData(std::move(aFontData)), + mDataLength(aDataLength), + mFTLibrary(aFTLibrary) {} + +NativeFontResourceFreeType::~NativeFontResourceFreeType() = default; + +template +already_AddRefed NativeFontResourceFreeType::CreateInternal( + uint8_t* aFontData, uint32_t aDataLength, FT_Library aFTLibrary) { + if (!aFontData || !aDataLength) { + return nullptr; + } + UniquePtr fontData(new (fallible) uint8_t[aDataLength]); + if (!fontData) { + return nullptr; + } + memcpy(fontData.get(), aFontData, aDataLength); + + RefPtr resource = new T(std::move(fontData), aDataLength, aFTLibrary); + return resource.forget(); +} + +#ifdef MOZ_WIDGET_ANDROID +already_AddRefed NativeFontResourceFreeType::Create( + uint8_t* aFontData, uint32_t aDataLength, FT_Library aFTLibrary) { + return CreateInternal(aFontData, aDataLength, + aFTLibrary); +} + +already_AddRefed NativeFontResourceFreeType::CreateUnscaledFont( + uint32_t aIndex, const uint8_t* aInstanceData, + uint32_t aInstanceDataLength) { + if (RefPtr face = CloneFace()) { + return MakeAndAddRef(std::move(face)); + } + return nullptr; +} +#endif + +already_AddRefed NativeFontResourceFreeType::CloneFace( + int aFaceIndex) { + RefPtr face = Factory::NewSharedFTFaceFromData( + mFTLibrary, mFontData.get(), mDataLength, aFaceIndex, this); + if (!face || + (FT_Select_Charmap(face->GetFace(), FT_ENCODING_UNICODE) != FT_Err_Ok && + FT_Select_Charmap(face->GetFace(), FT_ENCODING_MS_SYMBOL) != + FT_Err_Ok)) { + return nullptr; + } + return face.forget(); +} + +#ifdef MOZ_WIDGET_GTK +NativeFontResourceFontconfig::NativeFontResourceFontconfig( + UniquePtr&& aFontData, uint32_t aDataLength, + FT_Library aFTLibrary) + : NativeFontResourceFreeType(std::move(aFontData), aDataLength, + aFTLibrary) {} + +already_AddRefed NativeFontResourceFontconfig::CreateUnscaledFont( + uint32_t aIndex, const uint8_t* aInstanceData, + uint32_t aInstanceDataLength) { + if (RefPtr face = CloneFace()) { + return MakeAndAddRef(std::move(face)); + } + return nullptr; +} + +already_AddRefed +NativeFontResourceFontconfig::Create(uint8_t* aFontData, uint32_t aDataLength, + FT_Library aFTLibrary) { + return CreateInternal(aFontData, aDataLength, + aFTLibrary); +} +#endif + +} // namespace mozilla::gfx -- cgit v1.2.3