# HG changeset patch # User Kenichi Handa # Date 1282716912 -32400 # Node ID d9cfc4f455fc58f5ef12a078e1a89dc87857d8ad # Parent d2bad2ecc287c9ff6b654252ff7d245dfc0b41fd# Parent 55e2c5cbf29cbd0678147a93a038500b18b63b8f merge trunk diff -r d2bad2ecc287 -r d9cfc4f455fc doc/lispref/ChangeLog --- a/doc/lispref/ChangeLog Wed Aug 25 14:15:20 2010 +0900 +++ b/doc/lispref/ChangeLog Wed Aug 25 15:15:12 2010 +0900 @@ -1,3 +1,7 @@ +2010-08-25 Eli Zaretskii + + * processes.texi (Filter Functions): Fix last change. + 2010-08-24 Markus Triska * processes.texi (Filter Functions): Use `buffer-live-p' instead diff -r d2bad2ecc287 -r d9cfc4f455fc doc/lispref/processes.texi --- a/doc/lispref/processes.texi Wed Aug 25 14:15:20 2010 +0900 +++ b/doc/lispref/processes.texi Wed Aug 25 15:15:12 2010 +0900 @@ -1286,7 +1286,7 @@ @end group @group (save-excursion - ;; r{Insert the text, advancing the process marker.} + ;; @r{Insert the text, advancing the process marker.} (goto-char (process-mark proc)) (insert string) (set-marker (process-mark proc) (point))) diff -r d2bad2ecc287 -r d9cfc4f455fc src/ChangeLog --- a/src/ChangeLog Wed Aug 25 14:15:20 2010 +0900 +++ b/src/ChangeLog Wed Aug 25 15:15:12 2010 +0900 @@ -1,5 +1,8 @@ 2010-08-25 Kenichi Handa + * fontset.c (reorder_font_vector): Prefer a font-spec specifying + :otf. + * composite.c (composition_compute_stop_pos): Don't break composition at PT. (composition_reseat_it): Likewise. Fix calculation of character diff -r d2bad2ecc287 -r d9cfc4f455fc src/fontset.c --- a/src/fontset.c Wed Aug 25 14:15:20 2010 +0900 +++ b/src/fontset.c Wed Aug 25 15:15:12 2010 +0900 @@ -283,6 +283,10 @@ #define RFONT_DEF_OBJECT(rfont_def) AREF (rfont_def, 2) #define RFONT_DEF_SET_OBJECT(rfont_def, object) \ ASET ((rfont_def), 2, (object)) +/* Score of RFONT_DEF is an integer value; the lowest 8 bits represent + the order of listing by font backends, the higher bits represents + the order given by charset priority list. The smaller value is + preferable. */ #define RFONT_DEF_SCORE(rfont_def) XINT (AREF (rfont_def, 3)) #define RFONT_DEF_SET_SCORE(rfont_def, score) \ ASET ((rfont_def), 3, make_number (score)) @@ -412,8 +416,13 @@ Lisp_Object font_def = RFONT_DEF_FONT_DEF (rfont_def); Lisp_Object font_spec = FONT_DEF_SPEC (font_def); int score = RFONT_DEF_SCORE (rfont_def) & 0xFF; + Lisp_Object otf_spec = Ffont_get (font_spec, QCotf); - if (! font_match_p (font_spec, font_object)) + if (! NILP (otf_spec)) + /* A font-spec with :otf is preferable regardless of encoding + and language.. */ + ; + else if (! font_match_p (font_spec, font_object)) { Lisp_Object encoding = FONT_DEF_ENCODING (font_def);