From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: Artur Malabarba Newsgroups: gmane.emacs.devel Subject: Re: Single quotes in Info Date: Wed, 28 Jan 2015 19:38:08 -0200 Message-ID: References: <87twzhgk84.fsf@wmi.amu.edu.pl> <83lhksshdm.fsf@gnu.org> <9ee0c895-a178-40e1-b1c8-ed2b97071c6b@default> <87h9vgglkz.fsf@wmi.amu.edu.pl> <83h9vcp0bq.fsf@gnu.org> <83y4onorcc.fsf@gnu.org> <83vbjrnd1f.fsf@gnu.org> Reply-To: bruce.connor.am@gmail.com NNTP-Posting-Host: plane.gmane.org Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable X-Trace: ger.gmane.org 1422481107 8723 80.91.229.3 (28 Jan 2015 21:38:27 GMT) X-Complaints-To: usenet@ger.gmane.org NNTP-Posting-Date: Wed, 28 Jan 2015 21:38:27 +0000 (UTC) Cc: emacs-devel To: Eli Zaretskii Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Wed Jan 28 22:38:26 2015 Return-path: Envelope-to: ged-emacs-devel@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 1YGaJb-0000dy-TZ for ged-emacs-devel@m.gmane.org; Wed, 28 Jan 2015 22:38:24 +0100 Original-Received: from localhost ([::1]:56076 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1YGaJb-0005gS-Dj for ged-emacs-devel@m.gmane.org; Wed, 28 Jan 2015 16:38:23 -0500 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:60094) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1YGaJT-0005ct-1C for emacs-devel@gnu.org; Wed, 28 Jan 2015 16:38:16 -0500 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1YGaJR-0002Nc-J2 for emacs-devel@gnu.org; Wed, 28 Jan 2015 16:38:14 -0500 Original-Received: from mail-oi0-x22a.google.com ([2607:f8b0:4003:c06::22a]:57509) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1YGaJN-0002Me-Lv; Wed, 28 Jan 2015 16:38:09 -0500 Original-Received: by mail-oi0-f42.google.com with SMTP id i138so20381719oig.1; Wed, 28 Jan 2015 13:38:09 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:reply-to:sender:in-reply-to:references:date:message-id :subject:from:to:cc:content-type:content-transfer-encoding; bh=38nrjyM3uh/iLWGmt08vfC2tTtHry5NUQUp9CCYfCFo=; b=LJs+wYpcivzDH32oal7UnpkAIfL0I4Uo7SUAkCpvIHI284WuoN6prrkiYzkgIOfZ8s RViQl9pHQ376kdi2b5mYiMpL4EELC+38LlFNOGaOYv1ZukZPpEMKeQbFr+HneHBs6lGN rFWW4gjQUsaJFRjmWkpt+qcKtoG7Tz6Ms3FS+YSJ0dLSItU7MGsT3j59Ke1MbgbVdzoN pLSpPZb5zE/kE5KW2kECCVqhZLhBNMG/EwESY+MlilAN60XukwHpghHCgMDffJ3a1f51 P9QHv9GzrCeCcaFuU7H4ubxePlRgNRpuFxp7Sok2iTyuCVpKS1V4zxqdjuwm64HSCxsR 9khQ== X-Received: by 10.60.176.8 with SMTP id ce8mr2221605oec.71.1422481088966; Wed, 28 Jan 2015 13:38:08 -0800 (PST) Original-Received: by 10.76.125.1 with HTTP; Wed, 28 Jan 2015 13:38:08 -0800 (PST) In-Reply-To: <83vbjrnd1f.fsf@gnu.org> X-Google-Sender-Auth: yC34jjUYB9MDje3ryr1ydZHg7xs X-detected-operating-system: by eggs.gnu.org: Error: Malformed IPv6 address (bad octet value). X-Received-From: 2607:f8b0:4003:c06::22a X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: "Emacs development discussions." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Original-Sender: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Xref: news.gmane.org gmane.emacs.devel:181944 Archived-At: I've been looking into what you suggest, but it seems the decomposition property won't be enough. It does give us the necessary information for things like =C3=A1 and =C3=A7, but it doesn't say anything = about the quotes (which was the whole inital point), nor about characters like =E2=87=92 (which I think someone else on this thread suggested). Furthermore, the point here would be to have "a" and "=C3=A1" match each other, but the decomposition of "=C3=A1" gives us two characters (as would be expected). How are we to programmatically know which of these two characters is to be considered equivalent to "a with accute"? Is it safe to assume it's the first character? Otherwise, if we demand that the user types a=C2=B4 to be able to match the =C3=A1 letter, then this feature seems kind of moot. 2015-01-28 13:24 GMT-02:00 Eli Zaretskii : >> Date: Tue, 27 Jan 2015 23:15:22 -0200 >> From: Artur Malabarba >> Cc: emacs-devel >> >> Eli, if I may ask, did you get a chance to see the code? (it's quite sho= rt) >> The last couple emails give me the impression we're not quite on the sam= e page. > > I did just now, and I don't think I was on a different page. > >> The purpose of this is to allow the user to search for complex character= s (such as curly quotes or any of these =EF=BC=82=E2=80=9C=E2=80=9D=E2=80= =9D=E2=80=9E=E2=B9=82=E3=80=9E=E2=80=9F=E2=80=9F=E2=9D=9E=E2=9D=9D=E2=9D=A0= =E2=80=9C=E2=80=9E=E3=80=9D=E3=80=9F=F0=9F=99=B7=F0=9F=99=B6=F0=9F=99=B8) b= y typing a simple character available on simple keyboards (such as the plai= n double quote "). > > But that's exactly where it falls short of supporting a more general > feature, which allows to find text that is "equivalent" to the one you > search for. The limitation to "simple characters available on simple > keyboards" might seem a no-brainer for predominantly ASCII text, but > it _is_ a serious limitation for any non-ASCII script, certainly for > complex scripts, which Emacs supports for years. > >> Each simple character, needs an entry on the `isearch-groups-alist' vari= able. The max number of entries we'll ever need on this alist (in the very = worst possible scenario) is the number of simple characters in a simple key= board (which is way less than 5000 last I checked). > > You seem to forget that modern keyboards and input methods support > much more than what meets the eye on the keyboard. Even Latin locales > provide non-ASCII characters such as =C3=A1 and =C3=A5. It is also not u= ncommon > to copy/paste a search string from some text, in which case the search > string could include the "complex" characters, but you'd still want to > find their "simple" equivalents; your code, which transforms only the > search string, cannot support this use case. Moreover, CJK locales > use input methods that can produce thousands of characters, and for > people in those cultures such input is "simple" because they can use > nothing simpler. > > Using a database that maps ASCII characters to regexps doesn't scale > for supporting these use cases. It doesn't even scale to the > above-mentioned Latin characters, because =C3=A1 has a sequence of 2 > characters "a =CC=81" as its canonical decomposition, so when I type =C3= =A1, I > expect to find both =C3=A1 and "a =CC=81", and vice versa. More complex = scripts > have several forms of the same letter, such as the "final" form used > in Arabic and Hebrew for the last letter in a word -- typing one of > these forms should find any other form. Etc. etc. -- there's a huge > complexity behind all this, and we need to support it if we want to be > respected as a text editor. > > The way to support this is similar to how we support case-insensitive > search: we "fold" each character, both in the search string and in the > text being searched, using case tables, and then compare the "folded" > characters. Similarly, to support equivalence, we need to produce a > canonical/equivalent decomposition from each character on both sides > of the comparison, and then compare the results. > > As I said before, we already have all the necessary data in the > 'decomposition' property of each character, we just need to use it in > a way that is similar to case tables, just slightly more complex > (because we are no longer talking single characters). > >> > > Does it relate a simple character to all its complex >> > > equivalents? Or does it relate each complex character to a simple al= ternative? >> > The latter. Read paragraph 1.1 of UAX #15 for the starting point, and >> > also section 3.7 of the Unicode Standard. >> If it's the latter, then it's the wrong way for us to do an automated ap= proach. What we need is to know the whole set of Unicode characters which i= s equivalent to a given ASCII character. Of course we can build this table = from the Unicode Standard (that's exactly what the `isearch-groups-alist' v= ariable is meant to do), I'm just saying an automated approach probably isn= 't viable here. > > I don't see why it won't be viable, or maybe I don't understand what > you mean by "automated" here. I certainly don't think we should limit > ourselves to "simple characters", not for something as general-purpose > as text search. This might be okay for Info only, but not if we want > it in isearch.el. > > My idea is to use the 'decomposition' property to decompose each > character in the search string and in the text being searched, when > they need to be compared. Exactly like we do with case-folding.