chromium/ui/gfx/linux/fontconfig_util.h

// Copyright 2019 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef UI_GFX_LINUX_FONTCONFIG_UTIL_H_
#define UI_GFX_LINUX_FONTCONFIG_UTIL_H_

#include <fontconfig/fontconfig.h>

#include "base/files/file_path.h"
#include "ui/gfx/font_render_params.h"
#include "ui/gfx/gfx_export.h"

namespace gfx {

struct FcPatternDeleter {};
ScopedFcPattern;

// Initializes FontConfig on a worker thread if a thread pool instance is
// available, otherwise initializes FontConfig in a blocking fashion on the
// calling thread.  If this function is not called, the first call to
// GetGlobalFontConfig() will implicitly initialize FontConfig.  Can be called
// on any thread.
GFX_EXPORT void InitializeGlobalFontConfigAsync();

// Retrieve the global font config. Must be called on the main thread.
GFX_EXPORT FcConfig* GetGlobalFontConfig();
GFX_EXPORT void OverrideGlobalFontConfigForTesting(FcConfig* config);

// FcPattern accessor wrappers.
GFX_EXPORT std::string GetFontName(FcPattern* pattern);
GFX_EXPORT std::string GetFilename(FcPattern* pattern);
GFX_EXPORT int GetFontTtcIndex(FcPattern* pattern);
GFX_EXPORT bool IsFontBold(FcPattern* pattern);
GFX_EXPORT bool IsFontItalic(FcPattern* pattern);
GFX_EXPORT bool IsFontScalable(FcPattern* pattern);
GFX_EXPORT std::string GetFontFormat(FcPattern* pattern);

// Return the path of the font. Relative to the sysroot config specified in the
// font config (see: FcConfigGetSysRoot(...)).
GFX_EXPORT base::FilePath GetFontPath(FcPattern* pattern);

// Returns the appropriate parameters for rendering the font represented by the
// font config pattern.
GFX_EXPORT void GetFontRenderParamsFromFcPattern(FcPattern* pattern,
                                                 FontRenderParams* param_out);

#if BUILDFLAG(IS_CHROMEOS_ASH)
// Adds a given directory to the available fonts in the application.
// Directory must start with `/run/imageloader/` (guaranteed by DLC).
// Returns whether the fonts were added or not. Will not add the same directory
// more than once.
GFX_EXPORT bool AddAppFontDir(const base::FilePath& dir);
#endif

}  // namespace gfx

#endif  // UI_GFX_LINUX_FONTCONFIG_UTIL_H_