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);
+			}
 		    }
-	        }
+		}
 	    }
         }