# HG changeset patch # User Kenichi Handa # Date 1177506717 0 # Node ID 5346cefbb15b69079f46810fcdcfe74ff5664c51 # Parent 933d1187678d2be39d1525e58d443dbd7e26e281 (reorder_font_vector): Check contents of font_def. (fontset_find_font): Fix previous change. diff -r 933d1187678d -r 5346cefbb15b src/fontset.c --- a/src/fontset.c Wed Apr 25 12:07:30 2007 +0000 +++ b/src/fontset.c Wed Apr 25 13:11:57 2007 +0000 @@ -465,7 +465,8 @@ for (i = 0; i < size; i++) { font_def = AREF (fontset_element, i + 3); - if (! NILP (AREF (font_def, 2))) + if (VECTORP (AREF (font_def, 2)) + && INTEGERP (AREF (AREF (font_def, 2), 1))) charset_id_table[i] = XINT (AREF (AREF (font_def, 2), 1)); else charset_id_table[i] = -1; @@ -547,7 +548,7 @@ struct face *face; int id, fallback; { - Lisp_Object base_fontset, elt, vec; + Lisp_Object base_fontset, elt, vec, font_def; int i, from, to; int font_idx; FRAME_PTR f = XFRAME (FONTSET_FRAME (fontset)); @@ -604,7 +605,7 @@ && enable_font_backend && EQ (base_fontset, Vdefault_fontset)) { - Lisp_Object script, font_spec, tmp; + Lisp_Object script, font_spec; script = CHAR_TABLE_REF (Vchar_script_table, c); if (NILP (script)) @@ -613,9 +614,11 @@ ASET (font_spec, FONT_REGISTRY_INDEX, Qiso10646_1); ASET (font_spec, FONT_EXTRA_INDEX, Fcons (Fcons (QCscript, script), Qnil)); - tmp = Fmake_vector (make_number (5), Qnil); - ASET (tmp, 3, font_spec); - ASET (vec, 3 + i, tmp); + font_def = Fmake_vector (make_number (3), Qnil); + ASET (font_def, 0, font_spec); + elt = Fmake_vector (make_number (5), Qnil); + ASET (elt, 2, font_def); + ASET (vec, 3 + i, elt); } #endif /* USE_FONT_BACKEND */ @@ -659,8 +662,6 @@ /* Find the first available font in the vector of RFONT-DEF. */ for (; i < ASIZE (vec); i++) { - Lisp_Object font_def; - elt = AREF (vec, i); if (NILP (elt)) continue;