From: "Fumitaka Tokumitsu" <toku345@gmail.com>
To: "Stefan Monnier" <monnier@iro.umontreal.ca>,
ファミマTカード(ポイント)からのお知らせ <p.confirm@ft.family.co.jp>
Cc: Eli Zaretskii <eliz@gnu.org>, emacs-devel@gnu.org, dgutov@yandex.ru
Subject: Re: UI inconveniences with M-.
Date: Sat, 02 May 2015 01:35:24 -0700 (PDT) [thread overview]
Message-ID: <1430555724149.e91f702e@Nodemailer> (raw)
In-Reply-To: <jwv1tj0e7j7.fsf-monnier+emacsbugs@gnu.org>
[-- Attachment #1: Type: text/plain, Size: 5883 bytes --]
にた泣かねけあせけかきねはきかきか
—
Sent from Mailbox
On Fri, May 1, 2015 at 11:21 PM, Stefan Monnier <monnier@iro.umontreal.ca>
wrote:
>> If the back-end conceals potentially useful information, it should be
>> fixed not to do so.
> "Conceal" makes it sound like it's ill-intentioned, done on purpose
> or something.
> For (defadvice find-tag ...), the problem is in advice.el.
> Patches welcome, but since this library is on the way out AFAIC, I'd
> recommend you don't bother spending time on it.
>> That you personally find that information always redundant does not
>> mean it's true for everyone else. There's more than one use case for
>> these queries, see below.
> We can't know what the user wants and handle all conceivable scenarios.
> Maybe the user really wants to jump to this chunk of code somewhere that
> does (fset foo bar) and hence ends up overriding the "official"
> definition of the function. But unless you can solve the halting
> problem and read the user's mind at the same time, we'll have to settle
> for something imperfect.
> etags.el also failed miserably in some scenarios which xref/elisp
> handles acceptably. E.g. try C-u M-. diff-mode-abrev-table RET.
>> That's your misunderstanding. I described my user experience from
>> using this new feature; I never said where the fixes should be made,
> Well, you kept insisting that it's not a question of backend, so maybe
> you didn't say where the fixes should go, but you did say where the blame
> should go.
>> Says you. Through my naive-user eyes, filtering 140 hits to provide
>> just a few is perfectly within the capabilities of the UI, at least in
>> principle.
> The 140 hits are just a list of locations. The UI has no fucking clue
> whether these are function definitions or what, nor does it know in
> which language the file is written.
>> IOW, the separation of functionality is in the wrong place. To be
>> useful, some of the "smarts" need to be on the UI side, where user
>> control can be best implemented, and where user intent is known much
>> better.
> The UI has to be agnostic. So the smarts can't be in the UI. The API
> can be extended to provide the extra smarts that the UI might need, of
> course. E.g. we could add to the API a function that sorts/groups the
> entries, so the etags backend can sort them based on "likelyhood" rather
> than group them by file.
>> I very much hope Emacs will continue to be able to support the kind of
>> activities I described above, which AFAIK are very important part of a
>> software developer's job throughout the industry.
> You fail to understand why complaint about etags.el. I'm not
> complaining about `etags', but about the etags.el front-end, which is in
> need of improvement to handle the case where the user is navigating
> several completely different projects and doesn't want one to pollute
> the other one.
>>> I've tried several times to make real use of it, but always found it
>>> completely unpalatable. What with having to build those damn TAGS
>>> files, remember to refresh them, remember where they are, constantly
>>> tell Emacs again where they are, deal with its inability to find the
>>> right spot and having to repeat the "C-u M-." finger gymnastics
>>> umpteen times.
>> Those are exaggerations.
> Partly, yes. I'm just venting my frustration with the tool, and
> pointing out that if xref/elisp (and xref/etags) has some downsides,
> etags.el had its own set of downsides. And some of those shouldn't be
> that hard to fix (tho they would probably be a lot easier if we didn't
> have to worry about annoying some old-time users because they'd have to
> slightly change their habits).
>> Building TAGS is almost instant, even in Emacs,
> The problem is not computer-time but human-time.
>> you need only refresh them very seldom, and Emacs offers the
>> place from which to load them so you don't need to remember.
> If Emacs knows where the file is, the user shouldn't need to be queried.
>> But this, again, is immaterial for this discussion. I hope you will
>> agree that, whatever issues we have with etags, replacing it with
>> something that lacks important functionality is not a good idea.
> As I said, going back to etags.el is not an option.
>> That "little detail" all but invalidates most of my use cases.
> Then don't use that backend. E.g. use xref-etags-mode.
>>> C-u M-. also lets you do loose matching, via completion, if your memory
>>> is failing you.
>> I don't think completion is the right tool for these searches, because
>> the name alone doesn't tell enough.
> Don't pretend you don't know about xref-apropos.
>> See above: you assume that the division of functionality between the
>> UI and the back-ends is at the right place.
> No I don't. I don't assume the API is fixed either. All I assume is
> that the UI can't know about the programming language or about the
> quality of any given answer, or any such thing.
>>> But to me, "find-tag" and "find-tag-tag" are not two different
>>> matches to my request. They're just two completely unrelated
>>> things: either I'm looking for one or I'm looking for the other.
>> Assuming you know what you are looking for, yes. I described a
>> situation that is frequent for me where you generally don't, at least
>> not well enough to be satisfied by a single exact match.
> And that's not what M-. for. For that we have xref-apropos.
>> And therein lies its weakness. I actually don't understand how this
>> kind of assumption could be allowed to exist, when the _default_
> Because this assumption is known to be obtainable, with help from the
> toolchain (the compiler will generally know with 100% certainty the few
> possible definitions matching a particular use).
> Stefan
[-- Attachment #2: Type: text/html, Size: 6781 bytes --]
next prev parent reply other threads:[~2015-05-02 8:35 UTC|newest]
Thread overview: 89+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <83zja6b3tc.fsf@gnu.org>
[not found] ` <54A24079.4020902@yandex.ru>
[not found] ` <m261ctczy1.fsf@gmail.com>
[not found] ` <54A2FF47.6010207@yandex.ru>
[not found] ` <m2h9wcwxrp.fsf@gmail.com>
[not found] ` <54A86135.7080004@yandex.ru>
[not found] ` <54A90002.7080009@gmx.at>
[not found] ` <54A9C3FB.7000602@yandex.ru>
[not found] ` <54AA3881.3080304@gmx.at>
[not found] ` <54ABBB47.7010603@yandex.ru>
[not found] ` <837fszx7iy.fsf@gnu.org>
[not found] ` <jwv618iqjvj.fsf-monnier+emacsbugs@gnu.org>
[not found] ` <83r3r5wqwv.fsf@gnu.org>
[not found] ` <jwvvbgh5vve.fsf-monnier+emacsbugs@gnu.org>
[not found] ` <83k2wxwexb.fsf@gnu.org>
[not found] ` <jwvoam9459c.fsf-monnier+emacsbugs@gnu.org>
[not found] ` <83fv7kwbow.fsf@gnu.org>
2015-04-29 2:41 ` UI inconveniences with M- Stefan Monnier
2015-04-29 6:10 ` Helmut Eller
2015-04-29 13:23 ` conflicting uses of next-error-function (was: UI inconveniences with M-.) Stefan Monnier
2015-04-29 16:58 ` conflicting uses of next-error-function Helmut Eller
2015-04-29 17:40 ` Dmitry Gutov
2015-04-29 18:15 ` Helmut Eller
2015-04-29 23:14 ` Dmitry Gutov
2015-04-30 6:19 ` Helmut Eller
2015-04-30 8:04 ` Dmitry Gutov
2015-04-30 17:46 ` Helmut Eller
2015-05-02 23:20 ` Dmitry Gutov
2015-05-03 6:54 ` Helmut Eller
2015-05-03 11:45 ` Dmitry Gutov
2015-05-03 13:25 ` Helmut Eller
2015-05-03 14:12 ` Dmitry Gutov
2015-05-04 22:21 ` Ted Zlatanov
2015-05-05 2:28 ` Dmitry Gutov
2015-05-05 9:47 ` Ted Zlatanov
2015-05-05 14:05 ` Dmitry Gutov
2015-05-05 14:26 ` Ted Zlatanov
2015-04-29 23:05 ` Vitalie Spinu
2015-04-29 23:11 ` Dmitry Gutov
2015-04-29 23:52 ` Vitalie Spinu
2015-04-29 23:15 ` Dmitry Gutov
2015-04-30 6:35 ` Stefan Monnier
2015-04-29 15:26 ` UI inconveniences with M- Vitalie Spinu
2015-04-30 0:44 ` Dmitry Gutov
2015-04-30 0:55 ` Vitalie Spinu
2015-04-29 17:08 ` Dmitry Gutov
2015-04-29 15:44 ` Eli Zaretskii
2015-04-29 15:57 ` Dmitry Gutov
2015-04-29 16:17 ` Eli Zaretskii
2015-04-29 16:25 ` Dmitry Gutov
2015-04-29 16:53 ` Eli Zaretskii
2015-04-29 17:06 ` Dmitry Gutov
2015-04-29 17:15 ` Eli Zaretskii
2015-04-29 17:26 ` Dmitry Gutov
2015-04-29 17:59 ` Eli Zaretskii
2015-04-29 18:10 ` Dmitry Gutov
2015-04-29 21:54 ` Stefan Monnier
2015-04-30 13:42 ` Eli Zaretskii
2015-05-01 14:21 ` Stefan Monnier
2015-05-01 18:32 ` Eli Zaretskii
2015-05-01 21:04 ` Stefan Monnier
2015-05-01 21:13 ` Dmitry Gutov
2015-05-02 7:00 ` Stefan Monnier
2015-05-02 7:18 ` Eli Zaretskii
2015-05-02 8:35 ` Fumitaka Tokumitsu [this message]
2015-05-01 21:11 ` Dmitry Gutov
2015-05-02 8:12 ` Eli Zaretskii
2015-05-02 8:46 ` Fumitaka Tokumitsu
2015-05-02 12:41 ` Dmitry Gutov
2015-05-02 12:57 ` Eli Zaretskii
2015-05-02 13:31 ` Dmitry Gutov
2015-05-02 13:44 ` Eli Zaretskii
2015-05-02 17:44 ` Dmitry Gutov
2015-05-02 8:26 ` Fumitaka Tokumitsu
[not found] ` <553EB9D7.7010002@yandex.ru>
[not found] ` <jwvd22p2mfh.fsf-monnier+emacsbugs@gnu.org>
[not found] ` <553EC576.70903@yandex.ru>
[not found] ` <jwviochrqkt.fsf-monnier+emacsbugs@gnu.org>
[not found] ` <553EE468.4070203@yandex.ru>
[not found] ` <jwvlhhcqt3q.fsf-monnier+emacsbugs@gnu.org>
[not found] ` <553FF5DA.4090408@yandex.ru>
2015-04-29 3:13 ` Stefan Monnier
2015-04-29 3:25 ` Dmitry Gutov
2015-04-29 4:15 ` Stefan Monnier
[not found] ` <553EBBBF.6070509@yandex.ru>
[not found] ` <838udcwbdc.fsf@gnu.org>
[not found] ` <553FFC99.5080701@yandex.ru>
[not found] ` <834mnzuedd.fsf@gnu.org>
[not found] ` <554161A8.30202@yandex.ru>
[not found] ` <83618du3q3.fsf@gnu.org>
[not found] ` <5542E486.2010107@yandex.ru>
[not found] ` <83k2wsssm8.fsf@gnu.org>
[not found] ` <5543632C.6000306@yandex.ru>
[not found] ` <834mnwsbfb.fsf@gnu.org>
[not found] ` <554392E2.7080109@yandex.ru>
[not found] ` <83oam4qh2u.fsf@gnu.org>
[not found] ` <5543C97C.6050000@yandex.ru>
[not found] ` <83h9rwqf10.fsf@gnu.org>
[not found] ` <5543E3CF.5010402@yandex.ru>
2015-05-02 6:59 ` Stefan Monnier
2015-05-02 7:59 ` Helmut Eller
2015-05-02 8:39 ` Eli Zaretskii
2015-05-02 9:09 ` Helmut Eller
2015-05-02 9:24 ` Eli Zaretskii
2015-05-02 9:50 ` Helmut Eller
2015-05-02 18:29 ` Dmitry Gutov
2015-05-02 13:13 ` xref "find references" and grouping Dmitry Gutov
2015-05-02 14:14 ` Helmut Eller
2015-05-02 19:01 ` Dmitry Gutov
2015-05-03 7:47 ` Helmut Eller
2015-05-04 1:35 ` Stefan Monnier
2015-05-04 2:09 ` Dmitry Gutov
2015-05-04 13:10 ` Vitalie Spinu
2015-05-04 14:21 ` Vitalie Spinu
2015-05-04 21:29 ` Dmitry Gutov
2015-05-05 0:02 ` Vitalie Spinu
2015-05-05 0:18 ` Dmitry Gutov
2015-05-05 1:45 ` Vitalie Spinu
2015-05-02 19:10 ` UI inconveniences with M- Dmitry Gutov
2015-05-04 13:41 ` Vitalie Spinu
2015-05-04 21:34 ` Dmitry Gutov
2015-05-05 0:13 ` Vitalie Spinu
2015-05-05 0:14 ` Dmitry Gutov
2015-05-05 1:36 ` Vitalie Spinu
2015-05-05 15:06 ` Dmitry Gutov
[not found] ` <83pp6pwqnw.fsf@gnu.org>
[not found] ` <jwv1tj57b9o.fsf-monnier+emacsbugs@gnu.org>
[not found] ` <553EB74A.4030208@yandex.ru>
[not found] ` <jwvoam92niy.fsf-monnier+emacsbugs@gnu.org>
[not found] ` <83618gwbb1.fsf@gnu.org>
2015-04-29 3:12 ` Etags.el (was: UI inconveniences with M-.) Stefan Monnier
2015-04-29 15:52 ` Eli Zaretskii
2015-04-29 22:14 ` Etags.el Stefan Monnier
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1430555724149.e91f702e@Nodemailer \
--to=toku345@gmail.com \
--cc=dgutov@yandex.ru \
--cc=eliz@gnu.org \
--cc=emacs-devel@gnu.org \
--cc=monnier@iro.umontreal.ca \
--cc=p.confirm@ft.family.co.jp \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).