From: Dmitry Gutov <dgutov@yandex.ru>
To: "Juri Linkov" <juri@linkov.net>,
"Kévin Le Gouguec" <kevin.legouguec@gmail.com>
Cc: 45765@debbugs.gnu.org
Subject: bug#45765: [PATCH] 28.0.50; Change default-directory before prompting in project-compile
Date: Wed, 13 Jan 2021 03:06:37 +0200 [thread overview]
Message-ID: <6e5456e4-a5ac-3e54-2ced-0116a6e7a9dc@yandex.ru> (raw)
In-Reply-To: <87lfcywhyc.fsf@mail.linkov.net>
Hi Juri,
On 12.01.2021 20:46, Juri Linkov wrote:
>> Something like this maybe?
>>
>> +(defun project-compile (command &optional comint interactive)
>> +COMMAND and COMINT work as with `compile'. When calling this
>> +function from Lisp, you can pretend that it was called
>> +interactively by passing a non-nil INTERACTIVE argument."
>> + (interactive (list nil nil t))
>> + (let ((default-directory (project-root (project-current t))))
>> + (if interactive
>> + (call-interactively #'compile)
>> + (compile command comint))))
>>
>> (Apologies if I misunderstood what Juri asked, or if my suggestion is
>> buggy)
> Perfect, thank you for finding the middle ground for different needs.
So you're not worried about compilation-read-command in your code being
called in the wrong directory (exhibiting what the current bug report
aims to fix)?
I think you might as well inline the definition, it's almost as short:
(define-key my-map "m" ;; mnemonics "make"
(lambda ()
(interactive)
(let ((default-directory (project-root (project-current t))))
(compile
;; Use previous command from history
;; instead of the default from compile-command
(compilation-read-command (car compile-history))
;; Don't use compilation-shell-minor-mode
nil))))
But if you really like the new version of project-compile, OK.
I'm not a big fan of the 'interactive' argument. It could be replaced by
using (called-interactively-p 'interactive), though I'm not sure how
idiomatic that is.
next prev parent reply other threads:[~2021-01-13 1:06 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-01-10 12:57 bug#45765: [PATCH] 28.0.50; Change default-directory before prompting in project-compile Kévin Le Gouguec
2021-01-11 0:47 ` Dmitry Gutov
2021-01-11 18:35 ` Juri Linkov
2021-01-11 19:13 ` Dmitry Gutov
2021-01-11 21:24 ` Kévin Le Gouguec
2021-01-12 18:46 ` Juri Linkov
2021-01-13 1:06 ` Dmitry Gutov [this message]
2021-01-13 18:05 ` Juri Linkov
2021-01-13 19:46 ` Kévin Le Gouguec
2021-01-16 3:51 ` Dmitry Gutov
2021-01-19 17:38 ` Juri Linkov
2021-01-19 19:50 ` Dmitry Gutov
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=6e5456e4-a5ac-3e54-2ced-0116a6e7a9dc@yandex.ru \
--to=dgutov@yandex.ru \
--cc=45765@debbugs.gnu.org \
--cc=juri@linkov.net \
--cc=kevin.legouguec@gmail.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 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).