# HG changeset patch # User Kenichi Handa # Date 1181824421 0 # Node ID ac14f6e0bfff4a88bede15c68de91388f59c5463 # Parent 5ce347f4e5a9b3a4b7d8f2f37830034799526ded (update_compositions): Check the validness of compositions. diff -r 5ce347f4e5a9 -r ac14f6e0bfff src/composite.c --- a/src/composite.c Thu Jun 14 12:12:23 2007 +0000 +++ b/src/composite.c Thu Jun 14 12:33:41 2007 +0000 @@ -500,7 +500,8 @@ avoid it, in such a case, we change the property of the latter to the copy of it. */ if (from > BEGV - && find_composition (from - 1, -1, &start, &end, &prop, Qnil)) + && find_composition (from - 1, -1, &start, &end, &prop, Qnil) + && COMPOSITION_VALID_P (start, end, prop)) { if (from < end) Fput_text_property (make_number (from), make_number (end), @@ -510,7 +511,8 @@ from = end; } else if (from < ZV - && find_composition (from, -1, &start, &from, &prop, Qnil)) + && find_composition (from, -1, &start, &from, &prop, Qnil) + && COMPOSITION_VALID_P (start, end, prop)) run_composition_function (start, from, prop); } @@ -521,6 +523,7 @@ (to - 1). */ while (from < to - 1 && find_composition (from, to, &start, &from, &prop, Qnil) + && COMPOSITION_VALID_P (start, end, prop) && from < to - 1) run_composition_function (start, from, prop); } @@ -528,7 +531,8 @@ if (check_mask & CHECK_TAIL) { if (from < to - && find_composition (to - 1, -1, &start, &end, &prop, Qnil)) + && find_composition (to - 1, -1, &start, &end, &prop, Qnil) + && COMPOSITION_VALID_P (start, end, prop)) { /* TO should be also at composition boundary. But, insertion or deletion will make two compositions adjacent @@ -542,7 +546,8 @@ run_composition_function (start, end, prop); } else if (to < ZV - && find_composition (to, -1, &start, &end, &prop, Qnil)) + && find_composition (to, -1, &start, &end, &prop, Qnil) + && COMPOSITION_VALID_P (start, end, prop)) run_composition_function (start, end, prop); } }