You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
108 lines
3.7 KiB
108 lines
3.7 KiB
3 years ago
|
diff -ruN -x '*o' -x '*~' -x ttmkfdir -x parser.cpp ttmkfdir-3.0.9.orig/ttf.cpp ttmkfdir-3.0.9/ttf.cpp
|
||
|
--- ttmkfdir-3.0.9.orig/ttf.cpp 2006-11-29 15:46:55.000000000 +0900
|
||
|
+++ ttmkfdir-3.0.9/ttf.cpp 2006-11-29 17:21:40.000000000 +0900
|
||
|
@@ -70,7 +70,6 @@
|
||
|
Face::Face (const std::string &filename)
|
||
|
{
|
||
|
FT_Error fterror;
|
||
|
- string header_enc("-");
|
||
|
int face_id, face_count;
|
||
|
|
||
|
string::size_type pos = filename.rfind("/");
|
||
|
@@ -98,29 +97,13 @@
|
||
|
if ((post = (TT_Postscript *) FT_Get_Sfnt_Table(face, ft_sfnt_post)) == 0){
|
||
|
std::cout << "Warning: Can't get POST table : " << FileName << "(" << FT_Err_Post_Table_Missing << ")" << std::endl;
|
||
|
return;
|
||
|
- }
|
||
|
+ }
|
||
|
|
||
|
if ((os2 = (TT_OS2 *) FT_Get_Sfnt_Table(face, ft_sfnt_os2)) == 0) {
|
||
|
std::cout << "Warning: Can't get OS2 table : " << FileName << "(" << FT_Err_Table_Missing << ")" << std::endl;
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
- for (int j = 0; j < 32; j++) {
|
||
|
- switch (os2->ulCodePageRange1 & (1 << j)) {
|
||
|
- case TT_CODEPAGE_RANGE_932: /* Japanese */
|
||
|
- header_enc = "ji";
|
||
|
- break;
|
||
|
- case TT_CODEPAGE_RANGE_936: /* Simplified Chinese */
|
||
|
- header_enc = "gb";
|
||
|
- break;
|
||
|
- case TT_CODEPAGE_RANGE_949: /* Korean Wansung */
|
||
|
- header_enc = "ks";
|
||
|
- break;
|
||
|
- case TT_CODEPAGE_RANGE_950: /* Traditional Chinese */
|
||
|
- header_enc = "big";
|
||
|
- break;
|
||
|
- }
|
||
|
- }
|
||
|
/*
|
||
|
* Iterate over all cmap entries.
|
||
|
*/
|
||
|
@@ -148,25 +131,50 @@
|
||
|
*/
|
||
|
typedef Encodings_t::const_iterator MI;
|
||
|
std::pair<MI, MI> bounds = Encodings::instance()->equal_range (key);
|
||
|
+ bool need_non_cjk_encoding = true;
|
||
|
|
||
|
/*
|
||
|
* then look whether each of these encodings is present in this cmap.
|
||
|
*/
|
||
|
- for (Encodings_t::const_iterator i = bounds.first; i != bounds.second; i++) {
|
||
|
- if (MappingPresent (cmapidx,
|
||
|
- i->second->mappings[key],
|
||
|
- i->second->enc_size,
|
||
|
- i->second->start_code,
|
||
|
- (header_enc.compare("-")?((i->second->names[0].find(header_enc) != string::npos)?1:0):1)
|
||
|
- )) {
|
||
|
- /*
|
||
|
- * if the mapping is present, add all xlfd names for this mapping to the
|
||
|
- * list of available font names.
|
||
|
- */
|
||
|
- for (unsigned int k = 0; k < i->second->names.size (); k++) {
|
||
|
- add_entries (i->second->names[k],face_id);
|
||
|
+ for (int j = 0; j < 32; j++) {
|
||
|
+ string header_enc("-");
|
||
|
+
|
||
|
+ switch (os2->ulCodePageRange1 & (1 << j)) {
|
||
|
+ case TT_CODEPAGE_RANGE_932: /* Japanese */
|
||
|
+ header_enc = "ji";
|
||
|
+ break;
|
||
|
+ case TT_CODEPAGE_RANGE_936: /* Simplified Chinese */
|
||
|
+ header_enc = "gb";
|
||
|
+ break;
|
||
|
+ case TT_CODEPAGE_RANGE_949: /* Korean Wansung */
|
||
|
+ header_enc = "ks";
|
||
|
+ break;
|
||
|
+ case TT_CODEPAGE_RANGE_950: /* Traditional Chinese */
|
||
|
+ header_enc = "big";
|
||
|
+ break;
|
||
|
+ default:
|
||
|
+ if (need_non_cjk_encoding)
|
||
|
+ need_non_cjk_encoding = false;
|
||
|
+ else
|
||
|
+ continue;
|
||
|
+ break;
|
||
|
+ }
|
||
|
+ for (Encodings_t::const_iterator i = bounds.first; i != bounds.second; i++) {
|
||
|
+ if (MappingPresent (cmapidx,
|
||
|
+ i->second->mappings[key],
|
||
|
+ i->second->enc_size,
|
||
|
+ i->second->start_code,
|
||
|
+ (header_enc.compare("-")?((i->second->names[0].find(header_enc) != string::npos)?1:0):1)
|
||
|
+ )) {
|
||
|
+ /*
|
||
|
+ * if the mapping is present, add all xlfd names for this mapping to the
|
||
|
+ * list of available font names.
|
||
|
+ */
|
||
|
+ for (unsigned int k = 0; k < i->second->names.size (); k++) {
|
||
|
+ add_entries (i->second->names[k],face_id);
|
||
|
+ }
|
||
|
}
|
||
|
- }
|
||
|
+ }
|
||
|
}
|
||
|
}
|
||
|
|