From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: Eli Zaretskii Newsgroups: gmane.emacs.bugs Subject: bug#20727: 24.5; Font fallback doesn't work for the Emoji range Date: Sat, 13 Jun 2015 20:57:47 +0300 Message-ID: <83pp4zpk2s.fsf@gnu.org> References: <557B47B6.4080600@cs.ucla.edu> <837fr8q8dr.fsf@gnu.org> <83y4jnq0vz.fsf@gnu.org> <557C53E2.6070706@cs.ucla.edu> <83si9vpo0i.fsf@gnu.org> <557C633D.8090508@cs.ucla.edu> Reply-To: Eli Zaretskii NNTP-Posting-Host: plane.gmane.org X-Trace: ger.gmane.org 1434218365 27708 80.91.229.3 (13 Jun 2015 17:59:25 GMT) X-Complaints-To: usenet@ger.gmane.org NNTP-Posting-Date: Sat, 13 Jun 2015 17:59:25 +0000 (UTC) Cc: v.schneidermann@gmail.com, andrewjmoreton@gmail.com, 20727@debbugs.gnu.org To: Paul Eggert Original-X-From: bug-gnu-emacs-bounces+geb-bug-gnu-emacs=m.gmane.org@gnu.org Sat Jun 13 19:59:13 2015 Return-path: Envelope-to: geb-bug-gnu-emacs@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by plane.gmane.org with esmtp (Exim 4.69) (envelope-from ) id 1Z3pi2-0001MB-HE for geb-bug-gnu-emacs@m.gmane.org; Sat, 13 Jun 2015 19:59:10 +0200 Original-Received: from localhost ([::1]:56638 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Z3pi1-0005iY-Sz for geb-bug-gnu-emacs@m.gmane.org; Sat, 13 Jun 2015 13:59:09 -0400 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:44654) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Z3phx-0005iT-Li for bug-gnu-emacs@gnu.org; Sat, 13 Jun 2015 13:59:07 -0400 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1Z3phu-0004RN-E9 for bug-gnu-emacs@gnu.org; Sat, 13 Jun 2015 13:59:05 -0400 Original-Received: from debbugs.gnu.org ([140.186.70.43]:38463) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Z3phu-0004RJ-BG for bug-gnu-emacs@gnu.org; Sat, 13 Jun 2015 13:59:02 -0400 Original-Received: from Debian-debbugs by debbugs.gnu.org with local (Exim 4.80) (envelope-from ) id 1Z3phu-0005Vd-50 for bug-gnu-emacs@gnu.org; Sat, 13 Jun 2015 13:59:02 -0400 X-Loop: help-debbugs@gnu.org Resent-From: Eli Zaretskii Original-Sender: "Debbugs-submit" Resent-CC: bug-gnu-emacs@gnu.org Resent-Date: Sat, 13 Jun 2015 17:59:02 +0000 Resent-Message-ID: Resent-Sender: help-debbugs@gnu.org X-GNU-PR-Message: followup 20727 X-GNU-PR-Package: emacs X-GNU-PR-Keywords: confirmed Original-Received: via spool by 20727-submit@debbugs.gnu.org id=B20727.143421828521105 (code B ref 20727); Sat, 13 Jun 2015 17:59:02 +0000 Original-Received: (at 20727) by debbugs.gnu.org; 13 Jun 2015 17:58:05 +0000 Original-Received: from localhost ([127.0.0.1]:52923 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.80) (envelope-from ) id 1Z3pgy-0005UI-67 for submit@debbugs.gnu.org; Sat, 13 Jun 2015 13:58:05 -0400 Original-Received: from mtaout21.012.net.il ([80.179.55.169]:38816) by debbugs.gnu.org with esmtp (Exim 4.80) (envelope-from ) id 1Z3pgv-0005Tk-2E for 20727@debbugs.gnu.org; Sat, 13 Jun 2015 13:58:02 -0400 Original-Received: from conversion-daemon.a-mtaout21.012.net.il by a-mtaout21.012.net.il (HyperSendmail v2007.08) id <0NPW00J009VTE700@a-mtaout21.012.net.il> for 20727@debbugs.gnu.org; Sat, 13 Jun 2015 20:57:54 +0300 (IDT) Original-Received: from HOME-C4E4A596F7 ([87.69.4.28]) by a-mtaout21.012.net.il (HyperSendmail v2007.08) with ESMTPA id <0NPW00JGR9WDBO60@a-mtaout21.012.net.il>; Sat, 13 Jun 2015 20:57:54 +0300 (IDT) In-reply-to: <557C633D.8090508@cs.ucla.edu> X-012-Sender: halo1@inter.net.il X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.15 Precedence: list X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 140.186.70.43 X-BeenThere: bug-gnu-emacs@gnu.org List-Id: "Bug reports for GNU Emacs, the Swiss army knife of text editors" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: bug-gnu-emacs-bounces+geb-bug-gnu-emacs=m.gmane.org@gnu.org Original-Sender: bug-gnu-emacs-bounces+geb-bug-gnu-emacs=m.gmane.org@gnu.org Xref: news.gmane.org gmane.emacs.bugs:103906 Archived-At: > Date: Sat, 13 Jun 2015 10:07:09 -0700 > From: Paul Eggert > CC: v.schneidermann@gmail.com, andrewjmoreton@gmail.com, > 20727@debbugs.gnu.org > > > The Symbola font looks much more crisp on my system, FWIW. Which font > > back-end did you configure Emacs to use? > > Sorry, I don't know what "font back-end" means. The answer is here: > Does Emacs use -lm17n-flt? yes > Does Emacs use -lotf? yes > Does Emacs use -lxft? yes This means your font back-end is xft with libotf. That's the most advanced one we have on GNU and Unix systems, I think. I thought maybe you had something less advanced for some reason. > > Also, if you use the iso10646-1 variant instead of the iso8859-1 as > > the default font, doesn't that fix the problem > > Yes. The problem, I imagine, is that users will have put a fixed-width font of > their own preference into their .Xdefaults or .Xresources file (e.g., > "Emacs.font fixed"). This is reasonably common, and the recent change makes > symbols look much worse, at least in my environment. The question is how to avoid that without re-introducing the original problems. > By the way, I can reproduce a similar problem with "emacs -Q -font fixed". It's > not as unreadable there, but it's still pretty bad: Symbola characters have a > different width than the fixed-width characters that Emacs previously used, so > source code listings no longer line up. At some point, with sufficiently rare characters that are not well covered by fixed-width fonts, this will always happen. I don't think it's a catastrophe; it is certainly better than having the boxes with hex codes instead (which also make text misalign, btw). > > existing > > fonts are frequently inadequate, in that they claim support for > > Unicode ranges where they actually support only a handful of glyphs. > > Users then complain that they have decent fonts (like Symbola) > > installed, but Emacs still shows some characters as boxes with hex > > code, instead of using Symbola. > > This doesn't seem to be a problem in Ubuntu and/or Fedora (the systems I > typically use) I think you are judging by characters that are sufficiently well covered. Try Emoji (something in the range U+1F600 to U+1F64F), which was the trigger for this bug and my changes, or Enclosed Alphanumerics (U+1F100 to U+1F1FFF), for example. Or even Supplemental Punctuation (u+2E00 to u+2E7F) or Currency Symbols (u+20A0 to u+20CF). What I see on my system is that several fonts claim coverage, but typically support just a few characters, sometimes just one. That's the problem I was trying to avoid. > and on these environments the cure seems to be worse than the > disease. Is there some way we can heuristically tell whether we're > in an environment where glyphs are often not supported? It's not a matter of the environment, it's the matter of which fonts are installed. And sometimes, more installed fonts is worse, because some fonts claim support for Unicode ranges where their actual coverage is very scarce, tempting Emacs to try using them instead of better ones. > For example, can we convert a sample glyph or two to a bitmap and > see whether it looks like a boxed hex code? (Just thinking out > loud.) That's not necessary: Emacs can know whether a font supports a character without any analysis of the resultant bitmap (see font_has_char). The problem is that Emacs tries very hard not to open a font, and does all its font search without actually opening any fonts. By contrast, what you suggest is only possible once we open a font. I think the basic idea to augment the default fontset is correct, it just needs to be fine-tuned to not mess up users' most popular setups. > > I don't think it's a good idea to > > go back to the previous arrangement where any font that claimed > > iso10646-1 support would be considered as covering symbols and > > punctuation well, because that means restoring the problems I tried to > > fix in the first place. > > In that case I don't understand why emacs -Q -font > -misc-fixed-medium-r-semicondensed--13-120-75-75-c-60-iso10646-1 works now. If > Emacs is supposed to prefer Symbola to other fonts when displaying symbols, why > isn't it using Symbola in this case? Because -misc-fixed-medium-r-semicondensed--13-120-75-75-c-60-iso10646-1 is different from -misc-fixed-medium-r-semicondensed--13-120-75-75-c-60-iso8859-1, I think. The current code on master already does use the default font if it supports these characters, but -misc-fixed-medium-r-semicondensed--13-120-75-75-c-60-iso8859-1 doesn't, evidently. So Emacs tries to look for another font. Before my changes it would find -misc-fixed-medium-r-semicondensed--13-120-75-75-c-60-iso10646-1; after them, it tries Symbola first.