all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Juri Linkov <juri@linkov.net>
To: Pengji Zhang <me@pengjiz.com>
Cc: Jim Porter <jporterbugs@gmail.com>, 74287@debbugs.gnu.org
Subject: bug#74287: [PATCH] Rework history Isearch for Eshell
Date: Tue, 10 Dec 2024 09:46:27 +0200	[thread overview]
Message-ID: <8734iwq8to.fsf@mail.linkov.net> (raw)
In-Reply-To: <8734iwl5kw.fsf@pengjiz.com> (Pengji Zhang's message of "Tue, 10 Dec 2024 08:55:27 +0800")

>> So do you propose to add an internal variable that duplicates the user
>> option?
>
> Yes, sort of. It does not fully duplicates the user option though.
> Because we only need to force turning *on* history search, it is made to
> override the user option only when it is non-nil. Basically, it is
> something like:
>
> @@ -951,7 +954,8 @@ eshell--isearch-setup
>    (when (and
>           ;; Eshell is busy running a foreground process
>           (not eshell-foreground-command)
> -         (or (eq eshell-history-isearch t)
> +         (or eshell--force-history-isearch
> +             (eq eshell-history-isearch t)
>               (and (eq eshell-history-isearch 'dwim)
>                    (>= (point) eshell-last-output-end))))
>      (setq isearch-message-prefix-add "history ")
> @@ -975,7 +979,7 @@ eshell-history-isearch-end
>    (remove-hook 'isearch-mode-end-hook #'eshell-history-isearch-end t)
>    (setq isearch-opoint (point))
>    (unless isearch-suspended
> -    (custom-reevaluate-setting 'eshell-history-isearch)))
> +    (setq eshell--force-history-isearch nil)))

I agree this would be the right thing, because even in Isearch
we have variables that duplicate the user options such as e.g.
the option 'search-invisible' and the internal variable 'isearch-invisible'.





  reply	other threads:[~2024-12-10  7:46 UTC|newest]

Thread overview: 22+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-11-10  1:22 bug#74287: [PATCH] Rework history Isearch for Eshell Pengji Zhang
2024-11-10 23:40 ` James Thomas via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-11-12  8:54   ` Pengji Zhang
2024-11-26  6:53 ` Jim Porter
2024-11-26  9:41   ` James Thomas via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-11-26 17:00     ` Jim Porter
2024-11-27  5:37       ` James Thomas via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-12-04 18:56       ` Juri Linkov
2024-12-05 12:43         ` Pengji Zhang
2024-12-05 12:53           ` Pengji Zhang
2024-12-09  4:34             ` Jim Porter
2024-12-09 12:16               ` Pengji Zhang
2024-12-09 13:35                 ` Pengji Zhang
2024-12-09 19:06                   ` Jim Porter
2024-12-09 18:23                 ` Juri Linkov
2024-12-10  0:55                   ` Pengji Zhang
2024-12-10  7:46                     ` Juri Linkov [this message]
2024-12-10 11:01                       ` Pengji Zhang
2024-12-10 17:41                         ` Juri Linkov
2024-12-11  0:45                           ` Pengji Zhang
2024-12-11  7:06                             ` Juri Linkov
2024-12-11 19:58                         ` Jim Porter

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

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=8734iwq8to.fsf@mail.linkov.net \
    --to=juri@linkov.net \
    --cc=74287@debbugs.gnu.org \
    --cc=jporterbugs@gmail.com \
    --cc=me@pengjiz.com \
    /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 external index

	https://git.savannah.gnu.org/cgit/emacs.git
	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.