• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright (c) 2021 Huawei Device Co., Ltd. All rights reserved
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #ifndef FONTCONFIG_OHOS_H
6 #define FONTCONFIG_OHOS_H
7 
8 #include <json/json.h>
9 #include <vector>
10 
11 #include "SkFontDescriptor.h"
12 #include "SkFontHost_FreeType_common.h"
13 #include "SkFontStyle.h"
14 #include "SkStream.h"
15 #include "SkString.h"
16 #include "SkTypes.h"
17 
18 #include "FontInfo_ohos.h"
19 #include "SkTypeface_ohos.h"
20 
21 #ifdef ENABLE_DEBUG
22 
23 #define LOGE(fmt, args...)        \
24     printf("E %s:%d  %s - " fmt, basename(__FILE__), __LINE__, __FUNCTION__, ##args)
25 #define LOGI(fmt, args...)        \
26     printf("I %s:%d - " fmt,  __FUNCTION__, __LINE__, ##args)
27 #define LOGW(fmt, args...)        \
28     printf("W %s:%d  %s - " fmt, basename(__FILE__), __LINE__, __FUNCTION__, ##args)
29 
30 #else
31 
32 #define LOGE        SkDEBUGF
33 #define LOGI        SkDEBUGF
34 #define LOGW        SkDEBUGF
35 
36 #endif
37 
38 struct FontInfo;
39 struct FallbackInfo;
40 struct GenericFamily;
41 struct FallbackSetPos;
42 
43 using TypefaceSet = std::vector<sk_sp<SkTypeface_OHOS>>;
44 using GenericFamilySet = std::vector<std::unique_ptr<GenericFamily>>;
45 using FallbackSet = std::vector<std::unique_ptr<FallbackInfo>>;
46 using FallbackForMap = SkTHashMap<SkString, FallbackSetPos>;
47 using NamesMap = SkTHashMap<SkString, int>;
48 using Coordinate = SkFontArguments::VariationPosition::Coordinate;
49 using AxisDefinitions = SkTypeface_FreeType::Scanner::AxisDefinitions;
50 
51 /*!
52  * Error code definition
53  */
54 namespace ErrorCode {
55 
56 enum  {
57     NO_ERROR = 0,                           // no error
58     ERROR_CONFIG_NOT_FOUND,                 // the configuration document is not found
59     ERROR_CONFIG_FORMAT_NOT_SUPPORTED,      // the formation of configuration is not supported
60     ERROR_CONFIG_MISSING_TAG,               // missing tag in the configuration
61     ERROR_CONFIG_INVALID_VALUE_TYPE,        // invalid value type in the configuration
62     ERROR_FONT_NOT_EXIST,                   // the font file is not exist
63     ERROR_FONT_INVALID_STREAM,              // the stream is not recognized
64     ERROR_FONT_NO_STREAM,                   // no stream in the font data
65     ERROR_FAMILY_NOT_FOUND,                 // the family name is not found in the system
66     ERROR_NO_AVAILABLE_FAMILY,              // no available family in the system
67     ERROR_DIR_NOT_FOUND,                    // the directory is not exist
68 };
69 
70 } /* namespace ErrorCode */
71 
72 /*!
73  *  \brief To manage the related information of a 'fallbackFor' family name
74  */
75 struct FallbackSetPos {
76     unsigned int index; // the index of the first font style set in the fallback set for a specified family name
77     unsigned int count; // the count of font style sets for a specified family name
78 };
79 
80 /*!
81  * \brief To manage the information for a generic family item
82  */
83 struct GenericFamily {
84     SkString familyName; // the specified family name of the font style set
85     std::shared_ptr<TypefaceSet> typefaceSet; // the typeface set of the font style set
86     virtual ~GenericFamily() = default;
87 };
88 
89 /*!
90  * \brief To manage the information for a fallback family item
91  */
92 struct FallbackInfo : GenericFamily {
93     SkString langs; // the language for which the font style set is
94 };
95 
96 /*!
97  * \brief To parse the font configuration document and manage the system fonts
98  */
99 class FontConfig_OHOS {
100 public:
101     explicit FontConfig_OHOS(const SkTypeface_FreeType::Scanner& fontScanner,
102         const char* fname = nullptr);
103     virtual ~FontConfig_OHOS() = default;
104     const FallbackForMap& getFallbackForMap() const;
105     const FallbackSet& getFallbackSet() const;
106     int getFamilyCount() const;
107     int getDefaultFamily(SkString* familyName) const;
108     int getFamilyName(int index, SkString* familyName) const;
109     int getTypefaceCount(int styleIndex, bool isFallback = false) const;
110     int getStyleIndex(const char* familyName, bool& isFallback) const;
111 
112     SkTypeface_OHOS* getTypeface(int styleIndex, int index, bool isFallback = false) const;
113     SkTypeface_OHOS* getTypeface(int styleIndex, const SkFontStyle& style,
114         bool isFallback = false) const;
115 
116 #if ENABLE_DEBUG
117     void dumpFont(const FontInfo& font) const;
118     void dumpGeneric() const;
119     void dumpFallback() const;
120 #endif
121     bool hasError(int err, const SkString& text) const;
122     int getErrorCount() const;
123 
124     static sk_sp<SkTypeface_OHOS> matchFontStyle(const TypefaceSet& typefaceSet, const SkFontStyle& pattern);
125 
126     static const char* errToString(int err);
127 private:
128     struct AliasInfo;
129     struct AdjustInfo;
130     struct VariationInfo;
131     struct TtcIndexInfo;
132     using AliasMap = SkTHashMap<SkString, std::vector<AliasInfo>>;
133     using AjdustMap = SkTHashMap<SkString, std::vector<AdjustInfo>>;
134     using VariationMap = SkTHashMap<SkString, std::vector<VariationInfo>>;
135     using TtcIndexMap = SkTHashMap<SkString, TtcIndexInfo>;
136 
137     /*!
138      * \brief To manage the adjust information
139      */
140     struct AdjustInfo {
141         int origValue; // the real value of the font weight
142         int newValue; // the specified value of weight for a font
143     };
144 
145     /*!
146      * \brief To manage the alias information of
147      */
148     struct AliasInfo {
149         int pos; // the index of a font style set in generic family list.
150         int weight; // the weight of the font style set. 0 means no specified weight
151     };
152 
153     /*!
154      * \brief To manage the variation information
155      */
156     struct VariationInfo {
VariationInfoVariationInfo157         VariationInfo() : weight(-1), width(-1), slant(-1){}
158         std::vector<Coordinate> axis; // the axis set such as 'wght', 'wdth' and 'slnt'.
159         int weight; // the value of mapping weight
160         int width;  // the value of mapping width
161         int slant; // the value of mapping slant
162     };
163 
164     /*!
165      * \brief To manage the 'index' information for ttc fonts
166      */
167     struct TtcIndexInfo {
168         SkString familyName; // the family name of the first typeface in a ttc font
169         int ttcIndex; // the index of a typeface in a ttc font
170     };
171 
172     /*!
173      * \brief To manage the information of errors happened
174      */
175     struct ErrorInfo {
ErrorInfoErrorInfo176         ErrorInfo(int err, const char* text) : err(err), text(SkString(text)){}
ErrorInfoErrorInfo177         ErrorInfo(int err, SkString& text) : err(err), text(std::move(text)){}
178         int err; // error id
179         SkString text; // the part with error
180     };
181 
182     std::vector<SkString> fontDirSet; // the directories where the fonts are
183 
184     FallbackForMap    fallbackForMap; // a hash table to save the fallbackFor pairs
185     GenericFamilySet genericFamilySet; // the font style set list of generic family
186     FallbackSet fallbackSet; // the font style set list of fallback family
187 
188     NamesMap genericNames; // a map to store the index of a family for generic family
189     NamesMap fallbackNames; // a map to store the index of a family for fallback family
190 
191     std::vector<ErrorInfo> errSet; // the errors happened
192     AliasMap aliasMap; // to save alias information temporarily
193     AjdustMap adjustMap; // to save adjust information temporarily
194     VariationMap variationMap; // to save variation information temporarily
195     TtcIndexMap ttcIndexMap; // to save 'index' information temporarily
196 
197     int parseConfig(const char* fname);
198     int checkConfigFile(const char* fname, Json::Value& root);
199     int parseFontDir(const Json::Value& root);
200     int parseGeneric(const Json::Value& root);
201     int parseFallback(const Json::Value& root);
202     int parseFallbackItem(const Json::Value& root);
203     int parseAlias(const Json::Value& root, std::vector<AliasInfo>& aliasSet);
204     int parseAdjust(const Json::Value& root, std::vector<AdjustInfo>& adjustSet);
205     int parseVariation(const Json::Value& root, std::vector<VariationInfo>& variationSet);
206     int parseTtcIndex(const Json::Value& root, const SkString& familyName);
207     void getAxisValues(const AxisDefinitions& axisDefinitions,
208         const VariationInfo& variation, FontInfo& font) const;
209     bool insertTtcFont(int count, FontInfo& font);
210     bool insertVariableFont(const AxisDefinitions& axisDefinitions, FontInfo& font);
211     TypefaceSet* getTypefaceSet(const SkString& familyName, SkString& specifiedName) const;
212 
213     int loadFont(const SkTypeface_FreeType::Scanner& scanner, const char* fname);
214     int scanFonts(const SkTypeface_FreeType::Scanner& fontScanner);
215     void resetGenericValue();
216     void buildSubTypefaceSet(const std::shared_ptr<TypefaceSet>& typefaceSet,
217         std::shared_ptr<TypefaceSet>& subSet, const SkString& familyName, int weight);
218     void resetFallbackValue();
219     int logErrInfo(int err, const char* key, Json::ValueType expected = Json::nullValue,
220         Json::ValueType actual = Json::nullValue);
221     static void sortTypefaceSet(std::shared_ptr<TypefaceSet>& typefaceSet);
222     static uint32_t getFontStyleDifference(const SkFontStyle& style1, const SkFontStyle& style2);
223     static char* getFileData(const char* fname, int& size);
224     FontConfig_OHOS(const FontConfig_OHOS&) = delete;
225     FontConfig_OHOS& operator = (const FontConfig_OHOS&) = delete;
226     FontConfig_OHOS(FontConfig_OHOS&&) = delete;
227     FontConfig_OHOS& operator = (FontConfig_OHOS&&) = delete;
228 };
229 
230 #endif /* FONTCONFIG_OHOS_H */
231